react创建组件的三种方式及他们的异同点介绍:
一、函数式组件
(推荐教程:react教程)
1、语法
function myConponent(props) {return `Hello${props.name}`}
登录后复制
2、特点
新增了hooks的API可以去官网了解下,以前是无状态组件,现在是可以有状态的了
组件不能访问this对象
不能访问生命周期方法
3、建议:
如果可能,尽量使用无状态组件,保持简洁和无状态。【笔者的意思就是尽量用父组件去操控子组件,子组件用来展示,父组件负责逻辑】
二、es5方式React.createClass组件
1、语法
var myCreate = React.createClass({defaultProps: {//code},getInitialState: function() {return { //code };},render:function(){return ( //code );}})
登录后复制
2、特点
这种方式比较陈旧,慢慢会被淘汰
三、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属性类型和组件默认属性作为组建类的属性,不是组件实例的属性,所以使用类的静态性配置。
请大家瑾记创建组件的基本原则:
1、组件名首字母要大写
2、组件只能包含一个根节点(如果这个根节点你不想要标签将它包住的话可以引入Fragment
3、尽量使用函数式组件,保持简洁和无状态。
最后我们对比一下函数组件和class组件对于一个相同功能的写法差距:
由父组件控制状态的对比
函数组件:
function App(props) {function handleClick() {props.dispatch({ type: 'app/create' });}return{props.name}}
登录后复制
class组件
class App extends React.Component {handleClick() {this.props.dispatch({ type: 'app/create' });}render() {return{this.props.name}}}
登录后复制
自己维护状态的对比
import React, { useState } from 'react';function App(props) {const [count, setCount] = useState(0);function handleClick() {setCount(count + 1);}return{count}}
登录后复制
class组件:
class App extends React.Component {state = { count: 0 }handleClick() {this.setState({ count: this.state.count +1 })}render() {return{this.state.count}}}
登录后复制
以上就是react创建组件的三种方式分别是什么的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2721299.html