es6 三点运算符_ES6 扩展运算符 三个点(...)

本文详细介绍了ES6中的扩展运算符(...)的功能和用法,包括在函数调用、数组合并、替代apply方法、与解构赋值结合等方面的应用。示例代码展示了如何使用扩展运算符简化代码,提高效率。同时,由于TypeScript是ES6的超集,因此也支持扩展运算符。
摘要由CSDN通过智能技术生成

它是什么

es6中引入扩展运算符(...),它用于把一个数组转化为用逗号分隔的参数序列,它常用在不定参数个数时的函数调用,数组合并等情形。因为typeScript是es6的超集,所以typeScript也支持扩展运算符。

用在哪儿

可变参数个数的函数调用

function push(array, ...items) {

array.push(...items);

}

function add(...vals){

let sum=0;

for(let i=0;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];

end 2017-02-17 14:46:14

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值