ES6 新知识

...运算符

将一个数组转为用逗号分隔的参数序列。

        function push(array, ...items) {
                array.push(...items);
        }
        function add(x, y) {
                return x + y;
        }
        var numbers = [4, 38];
        add(...numbers) ;

可变参数个数的函数调用

            function push(array, ...items) {  
                array.push(...items);  
            }  

            function add(...vals){
                let sum=0;
                for(let i=0;i<vals.length;i++){
                    sum+=vals[i];
                }
                return sum;
            }

            let arr = [1,2,3,4,5,6];
            let sum = add(...arr);
            console.log(sum);  //21

更便捷的数组合并

        let arr1 = [1,2];
        let arr2 = [5,6];
        let newArr = [20];
        //es5 旧写法
        newArr = newArr.concat(arr1).concat(arr2); //[20,1,2,5,6]
        console.log(newArr);
        //es6 使用扩展运算符
        newArr = [20,...arr1,...arr2];  //[20,1,2,5,6]
        console.log(newArr);

替代es5的apply方法

        // ES5 的写法  
        function f(x, y, z) {  
        // ...  
        }  
        var args = [0, 1, 2];  
        f.apply(null, args);  
        // ES6 的写法  
        function f(x, y, z) {  
        // ...  
        }  
        var args = [0, 1, 2];  
        f(...args);  

求最大值Math.max()

            // ES5 的写法  
            Math.max.apply(null, [14, 3, 77])  
            // ES6 的写法  
            Math.max(...[14, 3, 77])  
            //  等同于  
            Math.max(14, 3, 77);  

通过push函数,将一个数组添加到另一个数组的尾部

        // ES5 的写法  
        var arr1 = [0, 1, 2];  
        var arr2 = [3, 4, 5];  
        Array.prototype.push.apply(arr1, arr2);  
        // ES6 的写法  
        var arr1 = [0, 1, 2];  
        var arr2 = [3, 4, 5];  
        arr1.push(...arr2);  

新建Date类型

        // ES5  
        new (Date.bind.apply(Date, [null, 2015, 1, 1]))  
        // ES6  
        new Date(...[2015, 1, 1]);  

与解构赋值结合,生成新数组

        // ES5  
        a = list[0], rest = list.slice(1)  
        // ES6  
        [a, ...rest] = list 

下面是另外一些例子。

        const [first, ...rest] = [1, 2, 3, 4, 5];  
        first // 1  
        rest // [2, 3, 4, 5]  
        const [first, ...rest] = [];  
        first // undefined  
        rest // []:  
        const [first, ...rest] = ["foo"];  
        first // "foo"  
        rest // [] 

将字符串转为真正的数组

        [...'hello']  
        // [ "h", "e", "l", "l", "o" ]  

将实现了 Iterator 接口的对象转为数组

        var nodeList = document.querySelectorAll('div');  
        var array = [...nodeList];
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值