js的传值和传址还是真绕,前回文说道

1.值类型是传值的

2.对象和数组是传址的

这两点通过例子的到了证实

然而还有一种情况没有讨论

函数的参数的传值和传址

通过实验,在函数中用一个新对象去覆盖传入的对象,则类似于传值的效果,原数据无法得到新值

var s = {value:}
var s1 = {value:} 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:}}
var s1 = {value:} function setValue(arg){
arg.sn = s1
} setValue(s) console.log(s.sn.value)
console.log(s1.value)

结果都是 2

通过外层再包装一层对象,成功的 把 s1取了出来,算是一种变通的方法吧

一个应用场景,其实是我在做web文件管理器时遇到的东西。

文件管理器要选择文件,单击一个文件,该文件会显示选中状态,按住ctrl继续单击其他文件,又会有一个文件显示选中状态

如果放开ctrl去选择另外的文件时要求曾经被选中的取消选中状态。说的有点儿绕,脑补吧,我也不知道咋描述了。

一个办法是你可以去用循环去取消之前的选中文件的选中状态,而另一个方法

将选中文件的状态都指向同一个状态对象,该对象的值是true,当要取消之前的若干选中时,只要把这个对象的值设置为false,则立即取消了所有被选中的文件。

而不用去循环处理过往数据。

以上

05-06 14:46