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

您所在的位置:网站首页 react创建组件 react创建组件的三种方式是什么

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

#react创建组件的三种方式是什么| 来源: 网络整理| 查看: 265

下面是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 {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教程

以上就是react创建组件的三种方式是什么的详细内容,更多请关注php中文网其它相关文章!



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3