为了账号安全,请及时绑定邮箱和手机立即绑定

用 ES6 畅快地写 JavaScript

标签:
JavaScript

图片描述
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协议
网络平台如需转载必须与本人联系确认。

点击查看更多内容
34人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消