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

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 
{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创建组件的三种方式是什么的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2716991.html

(0)
上一篇 2025年3月7日 22:00:25
下一篇 2025年2月18日 06:46:27

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论