ES5与ES6对比

1. 模块引用

1.在ES5里,引入React包基本通过require进行,代码类似这样:

// ES5
var React = require('react');
var { Component, PropTypes } = React;
console.log(Component);

在ES6里,import写法更为标准.

// ES6
import React, { Component, PropTypes } from 'react';
console.log(Component);

2. 导出单个类

// 在ES5里面,要导出一个类别的模块用,一般通过module.exports来导出。
var React = require('react');
var MyComponents = React.createClass({
render: function() {
return (<div>1111</div>)
}
});
module.exports = MyComponents; // 引用如下:
var c1 = require('./MyComponents'); // 在ES6里面 通过export default来导出类
// es6
export default class MyComponent extends Component {
render() { }
}
// 引用如下:
import MyComponent from './MyComponent';

3. 定义组件

// ES5里面, 通过React.createClass来定义一个组件类
// es5
var React = require('react');
var C1 = React.createClass({
render: function() {
return (
<C2 url='' />
)
}
}); // 在ES6里,通过定义一个继承自React.Component的class来定义一个组件类,像这样:
var React = require('react');
class C1 extends React.Component {
render() {
return (
<C2 url={ this.props.url }/>
)
}
}

4. 给组件定义方法

// ES5的写法
var React = require('react');
var C1 = React.createClass({
componentWillMount: function() { },
render: function() {
return (
<C2 url={ this.props.url } />
)
}
})
// ES6
var React = require('react');
class C1 extends React.Component {
componentWillMount() { }
render() {
return (
<div>222</div>
)
}
}

5. 定义组件的属性类型 和 默认属性

// 在ES5里,属性类型和默认属性分别通过propTypes成员和getDefaultProps方法来实现
var React = require('react');
var A = React.createClass({
getDefaultProps: function() {
return {
a: false,
b: 10,
};
},
propTypes: {
a: React.PropTypes.bool.isRequired,
b: React.PropTypes.number.isRequired,
c: React.PropTypes.string.isRequired,
d: React.PropTypes.string.isRequired,
},
render: function() {
return (
<C />
);
}
});
// 在ES6里,可以统一使用static成员来实现
var React = require('react');
//ES6
class A extends React.Component {
static defaultProps = {
a: false,
b: 10,
};
static propTypes = {
a: React.PropTypes.bool.isRequired,
b: React.PropTypes.number.isRequired,
c: React.PropTypes.string.isRequired,
d: React.PropTypes.string.isRequired,
};
// 注意这里有分号
render() {
return (
<C />
);
} // 注意这里既没有分号也没有逗号
}

6. 初始化STATE

//ES5
var React = require('react');
var A = React.createClass({
getInitialState: function() {
return {
loopsRemaining: this.props.maxLoops,
};
}
})
//ES6
var React = require('react');
class A extends React.Component {
constructor(props){
super(props);
this.state = {
loopsRemaining: this.props.maxLoops,
};
}
}

7. 把方法作为回调提供

//ES5
var React = require('react');
var A = React.createClass({
handleOptionsButtonClick: function(e) {
this.setState({showOptionsModal: true});
},
render: function(){
return (
<TouchableHighlight onClick={this.handleOptionsButtonClick}>
<Text>{this.props.label}</Text>
</TouchableHighlight>
)
}
}); // 在ES6下,你需要通过bind来绑定this引用,或者使用箭头函数(它会绑定当前scope的this引用)来调用
//ES6 var React = require('react');
class PostInfo extends React.Component{
handleOptionsButtonClick(e){
this.setState({showOptionsModal: true});
}
render(){
return (
<TouchableHighlight
onPress={this.handleOptionsButtonClick.bind(this)}
onPress={e=>this.handleOptionsButtonClick(e)}
>
<Text>{this.props.label}</Text>
</TouchableHighlight>
)
}
}

ES5与ES6对比的更多相关文章

  1. React入门 (1)—使用指南(包括ES5和ES6对比)

    前言 本篇会简明扼要的介绍一下React的使用方法.代码会用JSX+ES5和JSX+ES6两种方式实现. React简介 React来自Facebook,于2013年开源.至今不断修改完善,现在已经到 ...

  2. 多角度对比 ES5与ES6的区别

    ES5与ES6的对比不同点整理 本文关键词:ES6,javascript, 1.Default Parameters(默认参数) es6之前,定义默认参数的方法是在一个方法内部定义 var link ...

  3. JavaScript面向对象轻松入门之概述(demo by ES5、ES6、TypeScript)

    写在前面的话 这是一个JavaScript面向对象系列的文章,本篇文章主要讲概述,介绍面向对象,后面计划还会有5篇文章,讲抽象.封装.继承.多态,最后再来一个综合. 说实话,写JavaScript面向 ...

  4. JavaScript、ES5和ES6的介绍和区别

    JavaScript由三部分组成: ECMAScript(核心) DOM(文档对象模型) BOM (浏览器对象模型) ES5(ECMAScript第五个版本) strict模式 严格模式,限制一些用法 ...

  5. 创建对象—从es5到es6

    原文地址 本文主要讲述了使用JavaScript创建对象的几种方式,分别是传统的Object构造函数.对象字面量.工厂模式.构造函数模式.原型模式.组合模式,以及es6的class定义类.然后从bab ...

  6. ES5和ES6中对于继承的实现方法

    在ES5继承的实现非常有趣的,由于没有传统面向对象类的概念,Javascript利用原型链的特性来实现继承,这其中有很多的属性指向和需要注意的地方. 原型链的特点和实现已经在之前的一篇整理说过了,就是 ...

  7. JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)

    本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...

  8. JavaScript面向对象轻松入门之多态(demo by ES5、ES6、TypeScript)

    多态(Polymorphism)按字面的意思就是"多种状态",同样的行为(方法)在不同对象上有不同的状态. 在OOP中很多地方都要用到多态的特性,比如同样是点击鼠标右键,点击快捷方 ...

  9. ES5和ES6那些你必须知道的事儿(三)

    ES5和ES6那些你必须知道的事儿 ES6新增的东西 一.块级作用域:关键字let,常量const let与var的区别: a.不会进行变量声明提升 b.变量不允许被重复定义 c.变量不允许被删除 d ...

随机推荐

  1. 【IDEA&&Eclipse】3、IntelliJ IDEA 的 20 个代码自动完成的特性

    在这篇文章中,我想向您展示 IntelliJ IDEA 中最棒的 20 个代码自动完成的特性,可让 Java 编码变得更加高效.对任何集成开发环境来说,代码的自动完成都是最最重要的一项功能,它根据你输 ...

  2. js判断数据类型的四种方法

    1.typeof typeof是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的数据类型.返回的结果用该类型的字符串(全小写字母)形式表示,包括number,string,boolean,und ...

  3. 2017-07-29 中文代码示例教程之Java编程一天入门

    Java编程一天入门 v0.0.1 alpha 共享协议 本作使用署名-非商业使用-禁止演绎协议共享. 前言 Java入门代码用中文写(举例如下)更能被新手理解. 由于至今没有看到类似教程, 在此抛砖 ...

  4. 能用HTML/CSS解决的问题,就不要用JS

    原因:简单. 简单就意味着更快的开发速度,更小的维护成本,同时往往具有更好的体验. 一,导航高亮 效果图: 代码: <!DOCTYPE html> <html lang=" ...

  5. 【备忘】SQL语句增加字段、修改字段、修改类型、修改默认值

    一.修改字段默认值 alter table 表名 drop constraint 约束名字 ------说明:删除表的字段的原有约束 alter table 表名 add constraint 约束名 ...

  6. Ansible--常用模块使用(2)

    Ansible常用模块 cron 模块 用途:cron模块⽤于设置定时任务,也⽤于管理定时任务中的环境变量使用方法: [root@ansible ~]# ansible-doc -s cron - n ...

  7. Java虚拟机(一)结构原理与运行时数据区域

    我们来学习Java虚拟机的结构原理与运行时数据区域. 1.Java虚拟机概述 Oracle官方定义的Java技术体系主要包括以下几个部分: Java程序设计语言 各种平台的Java虚拟机 Class文 ...

  8. JVM内核优化

    1.垃圾回收器 JVM垃圾回收器有串行和并行两种. 1.1 Serial收集器(串行,单线程),现在使用较少 Serial一般收集新生代 SerialOld一般收集老年代(采用标记压缩算法) 1.2 ...

  9. Python中识别DataFrame中的nan

    # 识别python中DataFrame中的nanfor i in pfsj.index: if type(pfsj.loc[i]['WZML']) == float: print('float va ...

  10. WebDriverTest

    using OpenQA.Selenium.Firefox; using System; using System.Collections.Generic; using System.Linq; us ...