JavaScript-在js中改变参数变量值为什么会改变arguments对象的值

发布于 2016-10-29 01:52:17 字数 188 浏览 1263 评论 4

如:

function test(str) {
str = "world";
return "Hello, " + arguments[0];
}
test("javascript")
//Hello, world

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

虐人心 2017-04-30 22:53:42

arguments与真正传的形式参数是一致的,你给函数传了一个叫str的参数,并且只有这一个参数,那么str与arguments[0]都是对这个参数值的引用,改变其中一个值,即改变了二者所有的值。所以无法避免在函数内部给相同变量名str重新赋值时做到不影响arguments对象,建议换一个变量名。

偏爱自由 2017-04-11 20:24:13

不用这么纠结

 function test(str) {
var s = 'hello world, ' + str;
return str===arguments[0];
}
test("javascript") //-> True

晚风撩人 2016-12-29 23:25:01

原因我就不说了,见相关问题 @javascript 中函数的形参与 arguments 指向的不是同一个引用?

下面我说下,如何给相同变量名str重新赋值时,不影响arguments对象:

function test(str) {
    "use strict";
    str = "world";
    return "Hello, " + arguments[0];
}
test("javascript")

当然严格模式在 ECMAScript 5 中被支持,ie10 目前都不支持。

晚风撩人 2016-12-25 12:13:35

1,当参数不传的时候,arguments[0]与str是不会指向同一个引用的,如以下例子

 function test(str) {
str = "world";
return "Hello, " + arguments[0];
}
test(); //Hello, undefined

2,其实确实不用那么纠结,先用私有变量保存下传入的参数即可

 function test(str) {
var _str = str;
_str = "world";
return "Hello, " + arguments[0];
}
test("javascript"); //Hello, javascript

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文