令人头疼的 arguments

发布时间:2019-08-12 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了令人头疼的 arguments脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

下面这一题来自 javascript-puzzlers

function sidEffecting(ary) {
  ary[0] = ary[2]
}
function bar(a,b,c) {
  c = 10
  sidEffecting(arguments)
  return a + b + c
}
bar(1,1,1)

上述的结果是什么?答案是21,当然这是非严格模式,如果严格模式,那么答案为12。

以我的理解简单非严格模式下,函数形参arguments绑定,二者无论谁修改,都会互相影响。

但是,严格模式下,任何在函数体内的修改,或形参,或 arguments 只会影响自己,不会影响对方,可以修改下列代码试一试。

function test(a, b, c) {
    // 'use strict'
    VAR a = 4 
    console.LOG(a + b + c)
    // arguments[0] = 4
    console.log(arguments[0] + arguments[1] + arguments[2])
}

test(1,2,3)

严格模式下,参数的值不会随 arguments 对象的值的改变而变化。在正常模式下,对于第一个参数是 arg 的函数,对 arg 赋值时会同时赋值给 arguments[0],反之亦然(除非没有参数,或者 arguments[0] 被删除)。严格模式下,函数的 arguments 对象会保存函数被调用时的原始参数。arguments[i] 的值不会随与之相应的参数的值的改变而变化,同名参数的值也不会随与之相应的 arguments[i] 的值的改变而变化。

意思的是在ES6下,如果使用函数默认值,也会出现类似严格模式的效果。

function test(a, b, c = 3) {
    var a = 4 
    console.log(a + b + c)
    // arguments[0] = 4
    console.log(arguments[0] + arguments[1] + arguments[2])
}

test(1,2,3)

花了个小时,发现自己以前对严格模式理解还有不足,以后这道题作为面试题还不错。

原文首发于我的gIThub博客:https://github.com/isLishude/...

脚本宝典总结

以上是脚本宝典为你收集整理的令人头疼的 arguments全部内容,希望文章能够帮你解决令人头疼的 arguments所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。