继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

用 ES6 畅快地写 JavaScript

前端GoGoGo
关注TA
已关注
手记 59
粉丝 115
获赞 6940

图片描述
ES6 提供的许多新特性。用这些新特性,我们能在不降低代码可读性与维护性的基础上畅快地写 JavaScript~

箭头函数

将数组的内容 * 2

以前我们这么写

[1, 2, 3].map(function(each){
    return each * 2;
}); 

用 ES6 只需这样写

[1, 2, 3].map(each=> each * 2);
// 或
[1, 2, 3].map((each)=> each * 2);
// 或
[1, 2, 3].map((each) => {
    return each * 2;
});
默认参数

以前我们这么写

var introSomeBody = fuction(name){
    name = name || 'Jack';
}

用 ES6 只需这样写

var introSomeBody = (name = 'Jack') => {
}
不定参数

数字求和

以前我们这么写

var sumFn = function(){
    var nums = [].slice.call(arguments);
    var sum = nums.reduce(function(prev, curr){
        return prev + curr;
    }, 0);
    return sum;
}

用 ES6 只需这样写

var sumFn = (...nums) => {
    return nums.reduce((prev, curr)=>{
        return prev + curr;
    }, 0);
}
解构(Destructuring)赋值

交换两个变量的值

以前我们这么写

var temp = a;
a = b;
b = a;

用 ES6 只需这样写

[a, b] = [b, a]

参数赋值

以前我们这么写

var introSomeBody = fuction(options){
    var name = options.name || 'Jack';
    var age = options.age || 18;
    console.log('I am %s, I am %d years old', name, age);
}

用 ES6 只需这样写

var introSomeBody = ({name = "Jack", age = 18}) => {
    console.log('I am %s, I am %d years old', name, age);
}

模板字符串

拼多行字符串

以前我们这么写

var data = {
    name: '新闻',
    news: {
        name: 'Bable升级到6啦',
        content: 'Bable在某年某月升级到6啦,哈哈哈'
    }
};
var html = (
'<div class="box">' +
    '<h2 class="box-header">${name}</h2>' +
    '<div class="box-body">' +
        '<h3>${newsName}<h3>' +
        '<div>${newsContent}</div>' +
    '</div>' +
'</div>').replace('${name}', data.name)
        .replace('${newsName}', data.news.name)
        .replace('${newsContent}', data.news.content);

用 ES6 只需这样写

var data = {
    name: '新闻',
    news: {
        name: 'Bable升级到6啦',
        content: 'Bable在某年某月升级到6啦,哈哈哈'
    }
};
var html = `
<div class="box">
  <h2 class="box-header">${data.name}</h2>
  <div class="box-body">
     <h3>${data.news.name}<h3>
     <div>${data.news.content}</div>
  </div>
</div>
`;

想了解更多 ES6 相关知识,请阅读

本文遵守创作共享CC BY-NC-SA 4.0协议
网络平台如需转载必须与本人联系确认。

打开App,阅读手记
34人推荐
发表评论
随时随地看视频慕课网APP

热门评论

好样的,很不错的文章

变换两个变量那写错了吧

不错

查看全部评论