您好,欢迎访问一九零五行业门户网

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

区别:1、函数式定义无状态组件不能访问生命周期方法,而es5和es6的方法定义的是有状态的组件并且可以访问生命周期方法;2、es5方法中的函数this可以自动绑定,而es6方法中的函数this不能自动绑定,需要手动绑定。
本教程操作环境: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三种定义组件方法有什么区别的详细内容。
其它类似信息

推荐信息