ES6小技巧

接来写几个我平时在项目使用的最常用的几个优化的方法~

1- 数组去重
    var arr = [1,2,3,4,3,4]; 
    var arr2 = [...new Set(arr)];
  • 1
  • 2

这个时候arr2就是去重后的数组~


2- 交换两个变量的值
    let [x,y] = [1,2];
    [y,x] = [x,y];
    console.log(y);
  • 1
  • 2
  • 3

3- 获取字符串中的某个字符
    let arr= "hellomybo";
    console.log(arr[3]);
  • 1
  • 2

4- 使用箭头函数代替回调函数

ES5的写法

     let a1 = [1,2,3].map(function (x) {
                return x * x;
     });
  • 1
  • 2
  • 3

ES6 箭头函数写法

      let a2 = [1,2,3].map(x => x * x);

      console.log(a1,a2);
  • 1
  • 2
  • 3

5- 合并数组
    var arr1 = ['a', 'b'];
    var arr2 = ['c'];
    var arr3 = ['d', 'e'];
  • 1
  • 2
  • 3

// ES5的合并数组

    arr1.concat(arr2, arr3);
    // [ 'a', 'b', 'c', 'd', 'e' ]
  • 1
  • 2

// ES6的合并数组

    [...arr1, ...arr2, ...arr3]
    // [ 'a', 'b', 'c', 'd', 'e' ]
  • 1
  • 2

6- 字符串反转
    let str = "12345678900987654321";
  • 1

原始写法:

    str.split('').reverse().join('')
  • 1

展开写法:

    [...str].reverse().join('')
  • 1

7- 过滤需要的数值 和 获得计算后的数值

过滤:

    ['a',,'b'].filter(x => true)     // ['a','b']    
  • 1

计算:

    let arr = [1,2,3,4].map(x=>x+1);
    console.log(arr);
  • 1
  • 2
8-数组降维 使用generator迭代器
var arr = [1, [[2, 3], 4], [5, 6]];

var flat = function* (a) {
  var length = a.length;
  for (var i = 0; i < length; i++) {
    var item = a[i];
    if (typeof item !== 'number') {
      yield* flat(item);
    } else {
      yield item;
    }
  }
};

for (var f of flat(arr)) {
  console.log(f);
}
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值