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

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

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

(0)
上一篇 2025年3月7日 22:44:33
下一篇 2025年3月6日 21:08:46

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

相关推荐

  • react如何控制显示与隐藏

    react控制显示与隐藏的方法:1、通过state变量来控制是否渲染元素;2、通过style控制display属性;3、通过动态切换className。 本教程操作环境:windows7系统、React17版,Dell G3电脑。 reac…

    2025年3月7日
    100
  • 怎么修改react的antd默认样式

    react中修改antd默认样式的方法:首先给table添加一个div父元素,并设置个className;然后设置这个样式内的table表头样式。 本教程操作环境:windows7系统、React17版,该方法适用于所有品牌电脑。 reac…

    2025年3月7日
    200
  • 怎么下载react包

    下载react包的方法:首先安装react脚手架;然后安装淘宝cnpm命令工具;接着使用cd命令进入项目文件目录中;最后通过“npm init”和“cnpm install 依赖包名称”命令安装依赖包即可。 本教程操作环境:Windows7…

    2025年3月7日
    200
  • React中函数组件与类组件的区别是什么?

    区别:1、函数组件是一个纯函数,它接收一个props对象返回一个react元素;而类组件需要去继承React.Component并且创建render函数返回react元素。2、函数组件没有生命周期和状态state,而类组件有。 、 本文操作…

    2025年3月7日
    200
  • 为什么react适合做大型项目?

    原因:1、因为大型项目的庞大带来的是代码优化以及性能优化等问题,而react提倡的更细粒度的封装,带来的组件的复用性提高;且更高自由度的编写可以为手动优化性能带来更大的便利性。2、react社区活跃性高,可提供多样性的解决方案和更多的选择。…

    2025年3月7日
    200
  • redux和react有啥区别

    redux和react的区别有:1、redux是一个JavaScript状态容器,而react是Facebook推出的一个用来构建用户界面的JavaScript库;2、redux主要提供状态管理,而react主要用于构建UI等等。 本教程操…

    2025年3月7日
    200
  • 谷歌怎么安装react插件

    谷歌安装react插件的方法:首先依次点击Chrome的“菜单”->“更多工具”->“扩展程序”;然后点击“获取更多扩展程序”打开谷歌在线商店;最后搜索“React Developer Tools”插件并安装即可。 本教程操作环…

    2025年3月7日 编程技术
    200
  • react向数组中追加数据的方法

    具体方法如下: (免费视频教程:react视频教程) 首先渲染一个随机数,使其每间隔一秒变换一次,效果如下: 代码如下: nbsp;html>  数组追加元素       class Xpf extends React.Compone…

    2025年3月7日
    200
  • react怎么mock数据

    react mock数据的方法:首先在public目录下建立【/api/headerList.json】文件;然后加入相关代码【axios.get(‘/api/headerList.json’)】。 本教程操作环境:…

    2025年3月7日
    200
  • react可以引入css吗?

    react可以引入css,方法:1、直接在组件内部使用“style={{css样式}}”来引入css;2、render函数中先声明一个变量保存样式表绑定给style属性,然后引用;3、使用“import ‘css路径&#8217…

    2025年3月7日
    200

发表回复

登录后才能评论