1.用箭头函数减少代码(相信你在Vue已经看到了)

ES5:

function greetings (name) {
return 'hello ' + name
} ES6: const greetings = (name) => {
return 'hello $ {name}';
}

主要区别,表现在不需要使用function关键字来定义函数。

另一种ES6定义函数的方法:

const greetings = name => 'hello $ {name}';

1.如果你的函数只有一个参数,那么你可以围绕参数直接丢掉圆括号“()”

2.另一件事情就是,不用编写return关键字来返回值,因为在ES6中,如果你不在函数体内写入函数体,计算表达式会自动返回。

2.在ES6和ES5中操作对象

... 替代 Object.assign

ES5:

var obj1 = {a:1,b:2}
var obj2 = {a:2,c:3,d:4}
var obj3 = Object.assign(obj1,obj2) ES6:
const obj1 = {a:1,b:2}
const obj2 = {a:2,c:3,d:4}
const obj3 = {... obj1,... obj2}

ES5我们必须合并使用Object.assign()两个对象作为输入的对象并输出合并的对象。

提取多个值

ES5:

var obj1 = {a:1,b:2,c:3,d:4}
var a = obj1.a
var b = obj1.b
var c = obj1.c
var d = obj1.d ES6: const obj1 = {a:1,b:2,c:3,d:4}
const {
a,
b,
c,
d
} = obj1

对象引入的新功能

ES5:

var a = 1
var b = 2
var c = 3
var d = 4
var obj1 = {a:a,b:b,c:c,d:d} ES6: var a = 1
var b = 2
var c = 3
var d = 4
var obj1 = {a,b,c,d} //必须保持参数一致

3.Promises 与 回调

ES5中编写异步函数

ES5:

function isGreater (a, b, cb) {

  var greater = false
if(a > b) {
greater = true
}
cb(greater)
}
isGreater(1, 2, function (result) {
if(result) {
console.log('greater');
} else {
console.log('smaller')
}
}) //上面我们定义了一个名为的函数isGreater ,它有三个参数a ,b与cb 。当执行该功能时检查是否a大于b,并使该greater变量true ,如果不是greater停留false 。之后,isGreater调用回调函数cb并将该greater变量作为参数传递给函数。
//在下一段代码中,我们称该isGreater函数将它传递给我们ab与我们的回调函数一起传递。里面的回调函数我们检查结果是否是truefalse并根据它显示消息。 ES6: const isGreater = (a, b) => {
return new Promise ((resolve, reject) => {
if(a > b) {
resolve(true)
} else {
reject(false)
}
})
}
isGreater(1, 2)
.then(result => {
console.log('greater')
})
.catch(result => {
console.log('smaller')
}) //ES6 Promises 允许我们resolvereject一个请求。每当我们解决一个请求时,它会调用提供的回调函数,then并且每当我们拒绝一个请求时,它就会调用catch回调函数。
//ES6 Promises 比回调更好,因为它允许我们轻松地区分a 成功了或者是a 失败了,所以我们不必再次检查回调函数中的内容。

4.导出和导入模块(Vue用的很多吧!)

导出模块

ES5:

var myModule = {
x: 1,
y: function() { console.log('This is ES5') }
}
module.exports = myModule; ES6: const myModule = { x: 1, y: () => { console.log('This is ES6') } }
export default myModule;

ES6相对于ES5,增加了可读性,更人性化了。

导入模块

ES5:

var myModule = require('./myModule');

ES6:

import myModule from './myModule';

export default

ES5:

/*使用默认值 export default导出某个模块时,将导入这样一个模块
下面这行代码意味着类似这样的内容,我们默认导出了一个模块,所以我们必须在源文件中导入整个模块*/ import myModule from './myModule'; ES6: /*
为我们提供了导出多个(import)或单个(export)模块以及变量的能力
*/
export const x = 1;
export const y = 2;
export const z = 'String'; ES6是这样的: import {x, y, z} from './myModule';

es5~es6的更多相关文章

  1. Atitit js版本es5 es6新特性

    Atitit js版本es5 es6新特性 Es5( es5 其实就是adobe action script的标准化)1 es6新特性1 Es5( es5 其实就是adobe action scrip ...

  2. 简述ES5 ES6

    很久前的某一天,一位大神问我,你知道ES6相对于ES5有什么改进吗? 我一脸懵逼的反问,那个啥,啥是ES5.ES6啊. 不得不承认与大神之间的差距,回来深思了这个问题,结合以前的知识,算是有了点眉目. ...

  3. React/React Native的 ES5 ES6 写法对照

      ES5 ES6 模块 var React = require("react-native); var { Image, Text, View } = React;   import Re ...

  4. Atitit js es5 es6新特性 attilax总结

    Atitit js es5 es6新特性 attilax总结 1.1. JavaScript发展时间轴:1 1.2. 以下是ES6排名前十的最佳特性列表(排名不分先后):1 1.3. Es6 支持情况 ...

  5. 【转】React Native中ES5 ES6写法对照

    很多React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component),然而网上搜到的很多教程和例子都是 ...

  6. 【ES5 ES6】使用学习

    [ES5 ES6]使用学习 转载: ============================================================= 1.Promise 2.下划线转驼峰,驼 ...

  7. JavaScript Learning Paths(ES5/ES6/ES-Next)

    JavaScript Learning Paths(ES5/ES6/ES-Next) JavaScript Expert refs https://developer.mozilla.org/en-U ...

  8. React Native 的ES5 ES6写法对照表

    模块 引用 在ES5里,如果使用CommonJS标准,引入React包基本通过require进行,代码类似这样: //ES5 var React = require("react" ...

  9. ES5/ES6的区别研究(ECMAScript)

    我所理解的概念应该是语法的区别和特性的区别 这里是ECMAScript的解析http://baike.baidu.com/item/ECMAScript 参考: (ES6)http://es6.rua ...

  10. React/React Native 的ES5 ES6写法对照表

    //es6与es5的区别很多React/React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component ...

随机推荐

  1. caffe layer注册机制

    Caffe内部维护一个注册表用于查找特定Layer对应的工厂函数(Layer Factory的设计用到了设计模式里的工厂模式).Layer_factory的主要作用是负责Layer的注册,已经注册完事 ...

  2. QT5:总结篇 控件集合

    一.Layouts 二.Spacers 三.Buttons 四.Item Views(Model-Based) 五.Item Widgets(Item-Based) 六.Containers 七.In ...

  3. swift详解之九---------------自动引用计数、循环引用

    自动引用计数.循环引用(这个必须理解,必须看) 注:本文详细介绍自动引用计数,以及各种循环引用问题.一网打尽! 1. 自动引用计数原理 Swift 使用ARC机制来跟踪和管理你的内存,一般情况下,Sw ...

  4. image的resizeMode属性

    Image组件必须在样式中声明图片的宽和高.如果没有声明,则图片将不会被呈现在界面上.    我们一般将Image定义的宽和高乘以当前运行环境的像素密度称为Image的实际宽高. 当Image的实际宽 ...

  5. 5.1 qbxt 一测 T2

    求和[问题描述] 组合数 C(n,m)是从 n 个物品中取 m 个的方案数. C(n,m)=(n!)/(m!(n-m)!) 斐波那契数列 F 满足,F[0]=F[1]=1,n≥2 时 F[n]=F[n ...

  6. mysql单实例多库与多实例单库

    一.单实例多库: 一个mysql实例,创建多个数据目录. 规划: 实例路径:/usr/local/mysql 数据目录路径: (1)/usr/local/mysql/data (2)/usr/loca ...

  7. saltstack快速部署

    yum install wget deltarpm -y wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/rep ...

  8. LeetCode(65) Valid Number

    题目 Validate if a given string is numeric. Some examples: "0" => true " 0.1 " ...

  9. Python模块学习 - openpyxl读写excel

    openpyxl模块介绍 openpyxl模块是一个读写Excel 2010文档的Python库,如果要处理更早格式的Excel文档,需要用到额外的库,openpyxl是一个比较综合的工具,能够同时读 ...

  10. Leetcode 236.二叉树的最近公共祖先

    二叉树的最近公共祖先 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q,最近公共祖先表示为一个结点 x,满足 x ...