...扩展运算符的妙用

一、普通用法

const arr1 = [1, 2, 3, 4]
const arr2 = [5, 6, 7, 8]
const newArr = [...arr1, ...arr2]

二、当它被用在函数形参上时,它还可以把一个分离的参数序列整合成一个数组

function mutiple(...args) {
  let result = 1;
  for (var val of args) {
    result *= val;
  }
  return result;
}

mutiple(1, 2, 3, 4) // 24

在这个例子里,我们传入 mutiple 的是四个分离的参数,但是如果你在 mutiple 函数里尝试输出 args 的值,你会发现它是一个数

function mutiple(...args) {
  console.log(args)
}

mutiple(1, 2, 3, 4) // [1, 2, 3, 4]

三、用于类数组的转换

三种转换方法:

const arr = Array.prototype.slice.call(arrayLike)
const arr = Array.from(arrayLike)

扩展运算符——"…"也可以把类数组对象转换为数组,前提是这个类数组对象上部署了遍历器接口。在这个例子中,arrayLike 没有部署遍历器接口,所以这条路走不通。但一些对象,比如函数内部的 arguments 变量(它也是类数组对象),就满足条件,可以用这种方法来转换

function demo() {
  console.log('转换后的 arguments 对象:', [...arguments])
} 

demo(1, 2, 3, 4) // 转换后的 arguments 对象:[1, 2, 3, 4]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值