您好,欢迎访问一九零五行业门户网

react创建组件的三种方式是什么

下面是react创建组件的三种方式及特点,希望能够对大家有所帮助。
1、函数式组件:
(1)语法:
function myconponent(props) { return `hello${props.name}`}
(2)特点:
新增了hooks的api可以去官网了解下,以前是无状态组件,现在是可以有状态的了
组件不能访问this对象
不能访问生命周期方法
(3)建议:
如果可能,尽量使用无状态组件,保持简洁和无状态。【笔者的意思就是尽量用父组件去操控子组件,子组件用来展示,父组件负责逻辑】
2、es5方式react.createclass组件
(1)语法:
var mycreate = react.createclass({ defaultprops: { //code }, getinitialstate: function() { return { //code }; }, render:function(){ return ( //code ); }})
(2)特点:
这种方式比较陈旧,慢慢会被淘汰
(免费视频教程推荐:javascript视频教程)
3、es6方式class:
(1)语法:
class inputcontroles6 extends react.component { constructor(props) { super(props); this.state = { state_exam: props.exam } //es6类中函数必须手动绑定 this.handlechange = this.handlechange.bind(this); } handlechange() { this.setstate({ state_exam: 'hello world' }); } render() { return( //code ) };}
(2)特点:
成员函数不会自动绑定this,需要开发者手动绑定,否则this不能获取当前组件实例对象。
状态state是在constructor中初始化
props属性类型和组件默认属性作为组建类的属性,不是组件实例的属性,所以使用类的静态性配置。
请朋友们瑾记创建组件的基本原则:
组件名首字母要大写
组件只能包含一个根节点(如果这个根节点你不想要标签将它包住的话可以引入fragment,fragment不会用没关系,可以观看笔者的react基础知识整理(1)这篇文章)
尽量使用函数式组件,保持简洁和无状态。
最后我们对比一下函数组件和class组件对于一个相同功能的写法差距:
由父组件控制状态的对比
函数组件:
function app(props) { function handleclick() { props.dispatch({ type: 'app/create' }); } return <div onclick={handleclick}>{props.name}</div>}
class组件:
class app extends react.component { handleclick() { this.props.dispatch({ type: 'app/create' }); } render() { return <div onclick={this.handleclick.bind(this)}>{this.props.name}</div> }}
自己维护状态的对比
import react, { usestate } from 'react';function app(props) { const [count, setcount] = usestate(0); function handleclick() { setcount(count + 1); } return <div onclick={handleclick}>{count}</div>}
class组件:
class app extends react.component { state = { count: 0 } handleclick() { this.setstate({ count: this.state.count +1 }) } render() { return <div onclick={this.handleclick.bind(this)}>{this.state.count}</div> }}
相关推荐:react教程
以上就是react创建组件的三种方式是什么的详细内容。
其它类似信息

推荐信息