JavaScript 新旧替换三:参数转换

本文介绍了在JavaScript中如何使用ES2015及以后的展开运算符替代ES5的apply方法进行参数转换。讨论了在处理一般对象、数组、字符串等方面的应用,并详细阐述了如何在复制、合并对象或数组以及与解构赋值结合的场景下使用展开运算符。同时,文章提到了展开运算符在对象和数组解构中的注意事项和限制条件。
摘要由CSDN通过智能技术生成

引子

在 ES2015 之前,有把函数的 arguments 转变为某种可以当作数组来使用的方法,现在可以摆脱这些方法了。

这是继 JavaScript 新旧替换二:赋值和取值的第三篇。

ES5 方式

主要是使用了 apply() 方法,该方法用途是在特定的作用域中调用函数,实际上等于设置函数体内 this 对象的值。该接受两个参数:一个是在其中运行函数的作用域,另一个是参数数组。其中,第二个参数可以是 Array 的实例,也可以是 arguments 对象。

function foo() {
   
  var args = Array.prototype.slice.apply(arguments);
  console.info(args); // [1,2,3,4,5]
  console.info(args instanceof Array); // true
}
foo(1,2,3,4,5);

ES2015+ 方式

在 ES2015 中引入了一个新的运算符 ...,称为 spreadrest(展开或收集)运算符。不同情况下,会有不同的特性。

function foo(...args) {
   
  console.info(args); // [1,2,3,4,5]
  console.info(...args); // 1 2 3 4 5
}
foo(1,2,3,4,5);

这里运算符 ... 使用的特性有:

  • foo(...args) 中使用了收集的特性,把一系列值收集到一起成为一个数组。
  • console.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值