JS之arguments 引发的一个错误
16lz
2021-01-22
function abss(x){ alert(arguments[0]); for(var x=,0 ; x <arguments.length;x++){ if(arguments[x]>0){ alert(arguments[x]); }else{ alert(-arguments[x]); } } }
今天早上在学习JS的过程中,写了这么一段代码,结果在进行测试的时候,abss(5,10,10,2)的时候,出现了一个奇妙的情况,它的弹出框输出的结果为(5,0,10,10,2).
很奇特吧?
如果for循环里面申明的变量X覆盖了形参X的值,为什么后面会输出10?
如果没有覆盖的话,为什么第一个变量的值会输出0呢?
在这个arguments的介绍里面,有这么一段话,
arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。
对于arguments和值都存在的情况下,两者值是同步的。
但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。
function f(a, b, c){ alert(arguments.length); // result: "2" a = 100; alert(arguments[0]); // result: "100" arguments[0] = "qqyumidi"; alert(a); // result: "qqyumidi" alert(c); // result: "undefined" c = 2012; alert(arguments[2]); // result: "undefined" } f(1, 2);
那么上面的出现的结果就可以理解了。
我的函数定义的时候,形参是X,因此arguments[0]的值其实是和X对应的,此外除了第一个值之外的,都是arguments独立存储的,因此修改第一个值的时候,arrguments[0],是会随着改变的,但是后面的就不会改变了。
一下的代码可以验证上面的猜想
function abss(x){ alert(arguments[0]); for(x=0 ; x <arguments.length;x++){ alert(arguments[0]); if(arguments[x]>0){ alert(arguments[x]); }else{ alert(arguments[x]); } } }在这段代码执行的过程中,我们反复的输出arguments[0]的值,就可以发现它的变化了,
5, 0 ,0 ,1 ,10, 2 ,10 ,3, 2
以上。有趣的事,执行一下的代码,也会出现上面的结果
function abss(x){
alert(arguments[0]);
for(var x=1 ; x <arguments.length;x++){
alert(arguments[0]);
if(arguments[x]>0){
alert(arguments[x]);
}else{
alert(arguments[x]);
}
}
}
更多相关文章
- 如何在JavaScript中编写适当的OOP代码?
- JavaScript 最佳实践:帮你提升代码质量
- 将对象值传递给指令而不是任何其他数据变量
- 关于JavaScript变量声明及其初始化的问题
- 利用javascript实现遍历xml文件的代码实例
- 如何使用变量填充iframe源?
- 使用JavaScript多态在子类中创建唯一变量而不覆盖
- javascript 的MD5代码备份,跟java互通
- javascript入门笔记(1)——变量和计算