- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
总结React 组件的三种写法.doc
总结 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
您可能关注的文档
- 店务管理篇连锁式标准化管理_图文.ppt
- 店铺合伙制计划书0118_图文.ppt
- 度评选优秀工作者方案_图文.doc
- 建筑业发展规划与产业政策_图文.ppt
- 建筑工程项目管理 情境四.ppt
- 建筑师职业道德_从业资格考试_资格考试认证_教育专区.ppt
- 建筑智能化施工组织设计_图文.docx
- 建设工程招投标与合同管理5章.ppt
- 建设工程招投标与合同管理6章.ppt
- 建设工程招投标与合同管理7章.ppt
- 六年级数学下册教学课件《解比例》.pptx
- 8.21.5 鸟类的生殖与发育(课件)八年级生物下册课件(苏教版).pptx
- 钠离子电池项目智能制造方案(范文参考).docx
- 2023-2024学年吉林省吉林市舒兰市七年级(上)期末语文试卷.docx
- 2024年吉林省吉林市丰满区亚桥实验学校中考数学三模试卷.docx
- 2023-2024学年吉林省辽源市东辽县七年级(上)期末英语试卷.docx
- 2023-2024学年吉林四平九年级数学第一学期期末水平检测试卷.docx
- 2023-2024学年吉林市蛟河市三校联考九年级(上)期末英语试卷.docx
- 2023-2024学年吉林松原九年级英语上册考场实战试卷.docx
- 电解液新材料项目智能制造方案.docx
最近下载
- 2024年华医网继续教育答案-冠心病中西医结合诊治新进展.docx VIP
- 益普索:汽车APP客户体验报告.pdf
- 临床生物化学检验技术.docx
- 医学装备工作流程.docx VIP
- [安庆项目资料库]安庆市中心城区排水【雨水)防涝综合规划(2013-2030)·文本.pdf
- F系列卧式沸腾干燥机使用说明.pdf
- 脑卒中患者用药教育参考幻灯片.ppt
- 小升初数学:单位换算大全专项练习100道(小考复习精编专项)(长度单位+重量单位+面积单位+时间单位+容积、体积单位)六年级数学小升初复习系列(含知识点+答案).docx
- 2024-2025学年高中历史选择性必修1教学课件 第四单元-第14课 当代中国的外交.pptx
- 幼儿园餐中保育案例及分析总结.docx VIP
文档评论(0)