type Props={};
Components
Learn how to type React class components and stateless functional components with Flow
Adding Flow types to your React components is incredibly powerful. After typing your component, Flow will statically ensure that you are using the component in the way it was designed to be used.
Early in React’s history the library provided PropTypes
which performed basic runtime checks. Flow is much more powerful as it can tell you when you are misusing a component without running your code.
There are some Babel plugins which will generate PropTypes
from Flow types such as babel-plugin-react-flow-props-to-prop-types
if you want both static and runtime checks.
Class Components
Before we show how to type a React class component with Flow, let us first show how you would write a React class component without Flow but with React’s prop types. You would extend React.Component
and add a static propTypes
property.
1 |
|
Now, let’s Flowify the component we just wrote:
1 |
|
We removed our dependency on prop-types
and added a Flow object type named Props
with the same shape as the prop types but using Flow’s static type syntax. Then we passed our new Props
type into React.Component
as a type argument.
Now if you try to use <MyComponent>
with a string for foo
instead of a number you will get an error.
Now wherever we use this.props
in our React component Flow will treat it as the Props
type we defined.
Note: If you don’t need to use the
Props
type again you could also define it inline:extends React.Component<{ foo: number, bar?: string }>
.
Note: We import
React
as a namespace here withimport * as React from 'react'
instead of as a default withimport React from 'react'
. When importing React as an ES module you may use either style, but importing as a namespace gives you access to React’s utility types.
React.Component<Props, State>
is a generic type that takes two type arguments. Props and state. The second type argument, State
, is optional. By default it is undefined so you can see in the example above we did not include State
. We will learn more about state in the next section…
Adding State
To add a type for state to your React class component then create a new object type, in the example below we name it State
, and pass it as the second type argument to React.Component
.
1 |
|
In the example above we are using a React setState()
updater function but you could also pass a partial state object to setState()
.
Note: If you don’t need to use the
State
type again you could also define it inline:extends React.Component<{}, { count: number }>
.
Using Default Props
React supports the notion of defaultProps
which you can think of as default function arguments. When you create an element and you did not include a prop with a default then React will substitute that prop with its corresponding value from defaultProps
. Flow supports this notion as well. To type default props add a static defaultProps
property to your class.
1 |
|
Flow will infer the type of your default props from static defaultProps
so you don’t have to add any type annotations to use default props.
Note: You don’t need to make
foo
nullable in yourProps
type. Flow will make sure thatfoo
is optional if you have a default prop forfoo
.
Stateless Functional Components
In addition to classes, React also supports stateless functional components. You type these components like you would type a function:
1 |
|
Using Default Props for Functional Components
React also supports default props on stateless functional components. Similarly to class components, default props for stateless functional components will work without any extra type annotations.
1 |
|
Note: You don’t need to make
foo
nullable in yourProps
type. Flow will make sure thatfoo
is optional if you have a default prop forfoo
.
type Props={};的更多相关文章
- 一步一步带你实现virtual dom(二) -- Props和事件
很高兴我们可以继续分享编写虚拟DOM的知识.这次我们要讲解的是产品级的内容,其中包括:设置和DOM一致性.以及事件的处理. 使用Babel 在继续之前,我们需要弥补前一篇文章中没有详细讲解的内容.假设 ...
- React报错之JSX element type does not have any construct or call signatures
正文从这开始~ 总览 当我们试图将元素或react组件作为属性传递给另一个组件,但是属性的类型声明错误时,会产生"JSX element type does not have any con ...
- React报错之Type '() => JSX.Element[]' is not assignable to type FunctionComponent
正文从这开始~ 总览 当我们尝试从函数组件中返回元素组成的数组时,会产生"Type '() => JSX.Element[]' is not assignable to type Fu ...
- 【移动端兼容问题研究】javascript事件机制详解(涉及移动兼容)
前言 这篇博客有点长,如果你是高手请您读一读,能对其中的一些误点提出来,以免我误人子弟,并且帮助我提高 如果你是javascript菜鸟,建议您好好读一读,真的理解下来会有不一样的收获 在下才疏学浅, ...
- ReactJS入门(三)—— 顶层API
本文基本跟着官方文档把API都走一遍,但会有实例来解释应该怎么用,木有比我更详细的API文档咯. React.createClass 参数:CONFIG(object) 创建一个ReactClass( ...
- Npoi导入导出Excel操作
之前公司的一个物流商系统需要实现对订单的批量导入和导出,翻阅了一些资料,最后考虑使用NPOI实现这个需求. 在winform上面实现excel操作:http://www.cnblogs.com/Cal ...
- .NET 获取类型中的属性
解决方案 通过反射的方式获取类型中的所有属性. 引用命名空间 using System.Reflection; 实体类 public class User { private string ...
- pjax技术的应用
一.什么是PJAX? 现在有一些网站(apicloud, github)支持这样一种浏览方式,当你点击站内的一个连接的时候,不是传统的跳转到另外一个连接,而是类似ajax的局部刷新改变页面内容,但是 ...
- 【zepto学习笔记03】事件机制
前言 我们今天直接进入事件相关的学习,因为近期可能会改到里面的代码就zepto来说,我认为最重要的就是选择器与事件相关了,随着浏览器升级,选择器简单了,而事件相关仍然是核心,今天我们就来学习学习 ze ...
随机推荐
- Android SAX、DOM、Pull解析xml文件剖析与案例讲解
XML介绍 XML(Extensible Markup Language) 即可扩展标记语言,与HTML一样,都是SGML(Standard Generalized Markup Language,标 ...
- kvm虚拟机中virbr0虚拟网络接口的删除与恢复
安装 KVM 后都会发现网络接口里多了一个叫做 virbr0 的虚拟网络接口 一般情况下,虚拟网络接口virbr0用作nat,以允许虚拟机访问网络服务,但nat一般不用于生产环境.我们可以使用以下方法 ...
- linux常用命令之scp详解
使用scp的前提: 1.服务端启动了sshd服务 2.是本地和远程两端的系统都必须要有scp这个命令.即openssh-clients软件包 [安装方法] [root@ ~]# yum install ...
- python unittest框架中addCleanup函数详解
接上一篇doCleanups说明,这次介绍下另一个很好用的函数:addCleanup 还是老规矩,看官方文档说明: addCleanup(function, *args, **kwargs)¶ Add ...
- Edge Animate使用SPRITESHEET创建动画(三)
在Flash动画制作中,使用SpriteSheet制作动画元素是一个常见和普遍的方法.在Edge Animate中,我们也可以利用SpriteSheet来制作HTML5动画.本文将从一个示例出发,介绍 ...
- RabbitMQ服务端配置详解(转自:http://www.cnblogs.com/zhen-rh/p/6884297.html)
RabbitMQ支持三种配置方式: 1) 读取环境变量中配置, 这包括shell中环境变量和rabbitmq-env.conf/rabbitmq-env-conf.bat文件中配置的环境变量 可配置如 ...
- vue---指令怎么写
我们在考虑做一些功能性的封装的时候,我们会考虑使用vue的指令来做,那么指令应该怎么写: 具体参考: https://cn.vuejs.org/v2/guide/custom-directive.ht ...
- HDU 5727 - Necklace - [全排列+二分图匹配][Hopcroft-Karp算法模板]
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5727 Problem DescriptionSJX has 2*N magic gems. ...
- codeforces 792D - Paths in a Complete Binary Tree
#include<cstdio> #include<iostream> #define lowbit(x) x&(-x) typedef long long ll; u ...
- Oracle安装部署之Oracle 10g在redhat5下的安装
[root@localhost ~]# groupadd dba -g 111 [root@localhost ~]# groupadd oinstall -g 110 [root@localhost ...