createClass本质上是一个工厂函数,extends的方式更加接近最新的ES6规范的class写法。两种方式在语法上的差异主要体如今方法的定义和静态属性的声明上。createClass方式的方法定义使用逗号,隔开,由于creatClass本质上是一个函数,传递给它的是一个Object;而class的方式定义方法时务必谨记不要使用逗号隔开,这是ES6 class的语法规范。
React.createClass和extends Component的区别主要在于:javascript
React.createClasshtml
import React from 'react'; const Contacts = React.createClass({ render() { return ( <div></div> ); } }); export default Contacts;
React.Componentjava
import React from 'react'; class Contacts extends React.Component { constructor(props) { super(props); } render() { return ( <div></div> ); } } export default Contacts;
后一种方法使用ES6的语法,用constructor
构造器来构造默认的属性和状态。react
React.createClass:经过proTypes
对象和getDefaultProps()
方法来设置和获取props
.git
import React from 'react'; const Contacts = React.createClass({ propTypes: { name: React.PropTypes.string }, getDefaultProps() { return { }; }, render() { return ( <div></div> ); } }); export default Contacts;
React.Component:经过设置两个属性propTypes
和defaultProps
github
import React form 'react'; class TodoItem extends React.Component{ static propTypes = { // as static property name: React.PropTypes.string }; static defaultProps = { // as static property name: '' }; constructor(props){ super(props) } render(){ return <div></div> } }
React.createClass:经过getInitialState()
方法返回一个包含初始值的对象web
import React from 'react'; let TodoItem = React.createClass({ // return an object getInitialState(){ return { isEditing: false } } render(){ return <div></div> } })
React.Component:经过constructor
设置初始状态数组
import React from 'react'; class TodoItem extends React.Component{ constructor(props){ super(props); this.state = { // define this.state in constructor isEditing: false } } render(){ return <div></div> } }
React.createClass:会正确绑定this
函数
import React from 'react'; const Contacts = React.createClass({ handleClick() { console.log(this); // React Component instance }, render() { return ( <div onClick={this.handleClick}></div>//会切换到正确的this上下文 ); } }); export default Contacts;
React.Component:因为使用了 ES6,这里会有些微不一样,属性并不会自动绑定到 React 类的实例上。this
import React from 'react'; class TodoItem extends React.Component{ constructor(props){ super(props); } handleClick(){ console.log(this); // null } handleFocus(){ // manually bind this console.log(this); // React Component Instance } handleBlur: ()=>{ // use arrow function console.log(this); // React Component Instance } render(){ return <input onClick={this.handleClick} onFocus={this.handleFocus.bind(this)} onBlur={this.handleBlur}/> } }
咱们还能够在 constructor 中来改变 this.handleClick 执行的上下文,这应该是相对上面一种来讲更好的办法,万一咱们须要改变语法结构,这种方式彻底不须要去改动 JSX 的部分:
import React from 'react'; class Contacts extends React.Component { constructor(props) { super(props); this.handleClick = this.handleClick.bind(this); } handleClick() { console.log(this); // React Component instance } render() { return ( <div onClick={this.handleClick}></div> ); } } export default Contacts;
若是咱们使用 ES6 的方式来建立组件,那么 React mixins
的特性将不能被使用了。
React.createClass:使用 React.createClass 的话,咱们能够在建立组件时添加一个叫作 mixins
的属性,并将可供混合的类的集合以数组的形式赋给 mixins
。
import React from 'react'; let MyMixin = { doSomething(){} } let TodoItem = React.createClass({ mixins: [MyMixin], // add mixin render(){ return <div></div> } })