前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >带你玩转ECMAScript 6,助力你写出高效漂亮的代码

带你玩转ECMAScript 6,助力你写出高效漂亮的代码

作者头像
前端老鸟
发布2019-07-31 17:10:32
2500
发布2019-07-31 17:10:32
举报

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>
`;
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年07月19日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 箭头函数
  • 默认参数
  • 不定参数
  • 解构(Destructuring)赋值
  • 参数赋值
  • 模板字符串
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档