从ES6开始弱化arguments的作用
作者:砂糖橘加盐
这篇文章主要为大家介绍了从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的资料请关注脚本之家其它相关文章!