- 46
- 0
- 约1.11万字
- 约 10页
- 2017-02-14 发布于浙江
- 举报
总结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
- 2026中国跨平台排版软件技术突破与产业化路径研究.docx
- 2026农机生产销售行业市场现状供需分析及投资评估规划分析研究报告.docx
- 2026物流业市场发展分析及趋势前景与投资战略研究报告.docx
- 2026抗生素发酵得率提高菌种选育对临床症状治愈提速作用分析.docx
- 2026物流行业投资发展分析及风险投资策略研究报告.docx
- 2026商业航天产业发展现状及未来趋势预测报告.docx
- 2026中国气象主题公园规划设计与发展前景分析报告.docx
- 2026南非矿业市场现状分析投资评估行业前景布局规划报告.docx
- 2026亚洲数字经济国际合作模式研究及商业生态构建与投资价值分析报告.docx
- 2026养老服务产业盈利模式与市场发展分析.docx
最近下载
- 江苏航空职业技术学院单招职业适应性考试题库含答案详解【达标题】.docx VIP
- 【行业白皮书】赛迪:中国生物芯片白皮书.docx VIP
- 初中课堂注意力提升策略与项目式学习研究教学研究课题报告.docx
- 初中数学几何模型大全+经典题型(含答案)(可编辑修改word版).pdf VIP
- 《力度与速度》教案 2026人教版音乐一年级下册.doc VIP
- 小学生创造力发展与培养.ppt VIP
- 信息技术(基础模块):信息安全基础PPT教学课件.pptx VIP
- 2026人教版音乐八年级下册 第一单元《学习项目一:统一、变化与平衡》第1课时课件.ppt
- 07.中电建新能源集团有限公司智能光伏电站技术规范(2024版).pdf VIP
- 第二十九章 性发育异常疾病.pptx VIP
原创力文档

文档评论(0)