总结React组件的三种写法.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
总结React组件的三种写法

总结 React 组件的三种写法 React 专注于 view 层,组件化则是 React 的基础,也是其核心理念之一,一个完整的应用将由一个个独立的组件拼装而成。 截至目前 React 已经更新到 v15.4.2,由于 ES6 的普及和不同业务场景的影响,我们会发现目前主要有三种创建 React 组件的写法:1. ES5写法React.createClass,2. ES6写法React.Component,3. 无状态的函数式写法(纯组件-SFC)。 你们最钟爱哪种写法呢?萝卜青菜各有所爱~ 每个团队都有自己的代码规范和开发模式,但书写 React 组件时 都会以提高代码阅读性、更优的组件性能、易于 bug 追踪为原则。下面我们就聊聊这三种写法的区别,以及各自所适用场景的最佳实践。 ES5-写法 React.createClass React.createClass不用多说,我们最早使用这个方法来构建一个组件“类”,它接受一个对象为参数,对象中必须声明一个render方法,render返回一个组件实例,下面用一个 SwitchButton 组件的例子来看看React.createClass的具体用法: 复制代码 1 var React = require(react); 2 var ReactDOM = require(react-dom); 3 4 var SwitchButton = React.createClass({ 5 getDefaultProp:function() { 6 return { open: false } 7 }, 8 9 getInitialState: function() { 10 return { open: ps.open }; 11 }, 12 13 handleClick: function(event) { 14 this.setState({ open: !this.state.open }); 15 }, 16 17 render: function() { 18 var open = this.state.open, 19 className = open ? switch-button open : btn-switch; 20 21 return ( 22 label className={className} onClick={this.handleClick.bind(this)} 23 input type=checkbox checked={open}/ 24 /label 25 ); 26 } 27 }); 28 29 ReactDOM.render( 30 SwitchButton /, 31 document.getElementById(app) 32 ); 复制代码 ES6-写法 React.Component React 升级到 v0.13 后就支持了 ES6 的class语法,我们可以使用class App extends React.Component{...}的方式创建组件,这也是目前官方推荐创建有状态组件的方式。用 ES6 重写上面 SwitchButton 组件的例子: 复制代码 1 import React from react 2 import { render } from react-dom 3 4 class SwitchButton extends React.Component { 5 constructor(props) { 6 super(props) 7 this.state = { 8 open: ps.open 9 } 10 this.handleClick = this.handleClick.bind(this) 11 } 12 13 handleClick(event) { 14 this.setState({ open: !this.state.open }) 15 } 16 17 render() { 18 let open = this.state.open, 19 className = open ? switch-button open : btn-switch 20 21 return ( 22 label className={className} onClick={th

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档