从ES6开始弱化arguments的作用

 更新时间:2023年02月12日 11:01:32   作者:砂糖橘加盐  
这篇文章主要为大家介绍了从ES6开始弱化arguments的作用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

ES6弱化arguments的作用

通过一下手段:

  • 箭头函数没有arguments这个2.2 隐式参数
  • 形参可以有默认值
  • 数组结构方式
function test(...arr) {
  console.log(arr) // [[1, 3], 'c'] 是一个二维数组
}
test([1, 3], 'c')

其实从ES5中就有严格模式来限制arguments的操作. 不让它有共享,不让它有映射关系.

function test(a = 100) {
  arguments[0] = 10
  console.log(a, arguments[0])
}
test(1)

这里输出1, 和10. arguments并没有改变a的值.但是如果取消掉默认值的话,打印的结果就是 10, 10. 说明ES6的语法刻意的屏蔽掉arguments映射形参的作用.

当然,如果是在ES5中使用严格模式的话,也是把argument作用给屏蔽掉了

function test3(a) {
  "use strict"
  arguments[0] = 10
  console.log(a, arguments[0])
}
test3(1)

甚至于,arguments.callee 在严格模式下面也会报错了.

以上就是从ES6开始弱化arguments的作用的详细内容,更多关于ES6弱化arguments的资料请关注脚本之家其它相关文章!

相关文章

最新评论