es5与es6常用语法教程(4)

js常用语法系列教程如下

展开操作符(spread)

展开运算符(spread operator)允许一个表达式在某处展开。展开运算符在多个参数(用于函数调用)或多个元素(用于数组字面量)或者多个变量(用于解构赋值)的地方可以使用。

函数调用中使用展开运算符

在以前我们会使用apply方法来将一个数组展开成多个参数:

function test(a, b, c) {
  console.log(a, b, c) // 输出 0 1 2
}
var args = [0, 1, 2]
test.apply(null, args)

上面代码块中,我们把args数组当作实参传递给了a,b,c,这边正是利用了Function.prototype.apply的特性。

不过ES6有了展开运算符,我们就可以更加简洁地来传递数组参数:

function test(a, b, c) {
  console.log(a, b, c) // 输出 0 1 2
}
var args = [0, 1, 2]

test(...args)

我们使用...xxx展开运算符就可以把args展开直接传递给test()函数

数组字面量中使用展开运算符

  • 在ES6中,我们可以直接将一个数组合并到另一个数组中
let arr1 = ['a', 'b', 'c']
let arr2 = [...arr1, 'd', 'e']

console.log(arr2) // 输出:["a", "b", "c", "d", "e"] 

  • 展开运算符也可以用在push函数中,以后不需再用apply()函数来合并两个数组
let arr1=['a', 'b', 'c']
let arr2=['d', 'e']
arr2.push(...arr1)
console.log(arr2) // 输出:["d", "e", "a", "b", "c"]

用于解构赋值(rest)

  • 解构赋值也是ES6中的一个特性,而展开运算符可以用于部分情景
let [arg1, arg2, ...arg3] = [1, 2, 3, 4]
console.log(arg1) // 1
console.log(arg2) // 2
console.log(arg3) // [3, 4]

注意点:

  • 展开运算符在解构赋值中的作用跟上面的展开作用看上去是相反的,它是将多个元素合成了一个新数组。
  • 解构赋值中展开运算符只能用在最后面,不能用在其他的位置
  • 下面的用法就会报语法错误
let [arg1, ...arg2, arg3] = [1, 2, 3, 4]
console.log(arg1)
console.log(arg2)
console.log(arg3)

类数组对象变成数组

  • 展开运算符可以将一个类数组对象变成一个真正的数组对象
let list = document.getElementsByTagName('div')
let arr = [...list]
console.log(arr)
  • list是类数组对象,通过使用展开运算符将其变成了数组对象

对象展开运算符(ES7)

  • ES7中的对象展开运算符可以更快捷地操作对象
let {x, y, ...z} = {x: 1, y: 2, a: 3, b: 4}
console.log(x) // 1
console.log(y) // 2
console.log(z) // {a: 3, b: 4}
  • 如上面的代码块,我们可以将一个对象中的一部分抽取出来,成为一个新对象赋值给展开运算符
  • 我们也可以像数组中插入数组那样将一个对象插入到另外一个对象中
let z = {a: 3, b: 4}
let n = {x: 1, y: 2, ...z}
console.log(n) // {x: 1, y: 2, a: 3, b: 4}
  • 合并两个对象
let a = {x: 1, y: 2}
let b = {z: 3}
let c = {...a, ...b}
console.log(c) // {x: 1, y: 2, z: 3}

剩余操作符(rest)

  • rest操作符用在函数的参数内,将剩余的参数放到foods数组中
function breakfast(dessert, drink, ...foods) {
  console.log(dessert) // 🍰
  console.log(drink) // 🍺
  console.log(foods) // ["🍎", "🍐"]
}

breakfast ('🍰', '🍺', '🍎', '🍐')

注意点:

  • 和上面的解构赋值一样,剩余操作符只能用在函数的最后一个参数上,用在其他地方一样报语法错误。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 三,字符串扩展 3.1 Unicode表示法 ES6 做出了改进,只要将码点放入大括号,就能正确解读该字符。有了这...
    eastbaby阅读 1,591评论 0 8
  • 官方中文版原文链接 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大...
    HetfieldJoe阅读 3,046评论 3 37
  • 一、ES6简介 ​ 历时将近6年的时间来制定的新 ECMAScript 标准 ECMAScript 6(亦称 ...
    一岁一枯荣_阅读 6,128评论 8 25
  • 成为不了那样的人 积极做事 开开心心的笑脸迎人 是个好人 敢说话 我不敢 不敢出门 不敢见人 害怕 害怕被人类看见...
    TheF阅读 177评论 0 0
  • 之所以坚持说废话自然是有原因的,我发现有些事情写下来了就不用去想了,然后就可以想起其它的事,有时候并非是阅历...
    晓榄阅读 396评论 2 1