我是靠谱客的博主 安详大山,最近开发中收集的这篇文章主要介绍react三种定义组件方法有什么区别,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react三种定义组件方法有什么区别

React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归;具体的三种方式:

  • 函数式定义的无状态组件

  • es5原生方式React.createClass定义的组件

  • es6形式的extends React.Component定义的组件

1、无状态函数式组件

它是为了创建纯展示组件,这种组件只负责根据传入的props来展示,不涉及到state状态的操作

组件不会被实例化,整体渲染性能得到提升,不能访问this对象,不能访问生命周期的方法

2、ES5 原生方式 React.createClass // RFC

React.createClass会自绑定函数方法,导致不必要的性能开销,增加代码过时的可能性。

3、E6继承形式 React.Component // RCC

目前极为推荐的创建有状态组件的方式,最终会取代React.createClass形式;相对于 React.createClass可以更好实现代码复用。

无状态组件相对于于后二者的区别

与无状态组件相比,React.createClass和React.Component都是创建有状态的组件,这些组件是要被实例化的,并且可以访问组件的生命周期方法。

React.createClass****与React.Component区别

函数this自绑定

React.createClass创建的组件,其每一个成员函数的this都有React自动绑定,函数中的this会被正确设置。

React.Component创建的组件,其成员函数不会自动绑定this,需要开发者手动绑定,否则this不能获取当前组件实例对象。

组件属性类型propTypes及其默认props属性defaultProps配置不同

React.createClass在创建组件时,有关组件props的属性类型及组件默认的属性会作为组件实例的属性来配置,其中defaultProps是使用getDefaultProps的方法来获取默认组件属性的

React.Component在创建组件时配置这两个对应信息时,他们是作为组件类的属性,不是组件实例的属性,也就是所谓的类的静态属性来配置的。

组件初始状态state的配置不同

React.createClass创建的组件,其状态state是通过getInitialState方法来配置组件相关的状态;

React.Component创建的组件,其状态state是在constructor中像初始化组件属性一样声明的。

最后总结

只要有可能,尽量使用无状态组件创建形式。

能用React.Component创建的组件的就尽量不用React.createClass形式创建组件,以增强复用性和提高性能。

推荐学习:《react视频教程》

以上就是react三种定义组件方法有什么区别的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是安详大山为你收集整理的react三种定义组件方法有什么区别的全部内容,希望文章能够帮你解决react三种定义组件方法有什么区别所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(68)

评论列表共有 0 条评论

立即
投稿
返回
顶部