再谈js传值和传址
js的传值和传址还是真绕,前回文说道
1.值类型是传值的
2.对象和数组是传址的
这两点通过例子的到了证实
然而还有一种情况没有讨论
即
函数的参数的传值和传址
通过实验,在函数中用一个新对象去覆盖传入的对象,则类似于传值的效果,原数据无法得到新值
var s = {value:1} var s1 = {value:2} function setValue(arg){ arg = s1 } setValue(s) console.log(s.value) console.log(s1.value)
这个例子的结果是 s.value = 1 s1.value=2 ,相互没有影响。
那么问题来了
有时候硬是要通过传入参数取回返回值要如何做呢?
其实按照定义,是可以这么理解的,如果你覆盖了这个对象,则不是传址了,如果修改对象的一部分,则还是传址,不妨再做一个实验。
var s = {sn:{value:1}} var s1 = {value:2} function setValue(arg){ arg.sn = s1 } setValue(s) console.log(s.sn.value) console.log(s1.value)
结果都是 2
通过外层再包装一层对象,成功的 把 s1取了出来,算是一种变通的方法吧
一个应用场景,其实是我在做web文件管理器时遇到的东西。
文件管理器要选择文件,单击一个文件,该文件会显示选中状态,按住ctrl继续单击其他文件,又会有一个文件显示选中状态
如果放开ctrl去选择另外的文件时要求曾经被选中的取消选中状态。说的有点儿绕,脑补吧,我也不知道咋描述了。
一个办法是你可以去用循环去取消之前的选中文件的选中状态,而另一个方法
即
将选中文件的状态都指向同一个状态对象,该对象的值是true,当要取消之前的若干选中时,只要把这个对象的值设置为false,则立即取消了所有被选中的文件。
而不用去循环处理过往数据。
以上