类别:react / 日期:2022-12-24 / 浏览:209 / 评论:0

React.createClass 和 extends Component 的 bai 区别主要在于: 

(1)语法区别 createClass 本质上是一个工厂函数,extends 的方式更加接近最新 的 ES6 规范的 class 写法。两种方式在语法上的差别主要体现在方法 的定义和静态属性的声明上。

createClass 方式的方法定义使用逗号,隔开,因为 creatClass 本 质上是一个函数,传递给它的是一个 Object;而 class 的方式定义 方法时务必谨记不要使用逗号隔开,这是 ES6 class 的语法规范。-React

(2)propType 和 getDefaultProps

React.createClass:通过 proTypes 对象和 getDefaultProps()方法 来设置和获取 props.

React.Component:通过设置两个属性 propTypes 和 defaultProps

(3)状态的区别

React.createClass:通过 getInitialState()方法返回一个包含初 始值的对象

React.Component:通过 constructor 设置初始状态

(4)this 区别

React.createClass:会正确绑定 this

React.Component:由于使用了 ES6,这里会有些微不同,属性并不 会自动绑定到 React 类的实例上。

(5)Mixins

React.createClass:使用 React.createClass 的话,可以在创建组 件时添加一个叫做 mixins 的属性,并将可供混合的类的集合以数组 的形式赋给 mixins。

如果使用 ES6 的方式来创建组件,那么 React mixins 的特性将不 能被使用了。

版权声明 : 本文未使用任何知识共享协议授权,您可以任何形式自由转载或使用。

 可能感兴趣的文章

评论区

发表评论 / 取消回复

必填

选填

选填

◎欢迎讨论,请在这里发表您的看法及观点。

«    2023年11月    »
12345
6789101112
13141516171819
20212223242526
27282930

最新留言