JavaScript obj被赋值后值变化问题

    xiaoxiao2022-07-13  146

    在搞Js的时候发现一个问题,就是内存中保存的数据不对!!

    简单举个例子吧,如下:

    // 定义一个person对象 var person = { info: { name: "test" } }; var b = person.info; // b被赋值为person的info值 console.log(b); // person.info = {};//如果不想让b的值变化,可以这么写 person.info.name = "Hello"; person.info.age = "18"; console.log(b);

     

    输出如下:

    { name: 'test' } { name: 'Hello', age: '18' }

    从输出的结果中我们发现b的值变化 了,现在代码比较简单,大家发现问题也比较简单,就是b = person.info; 所以当person.info被重新赋值后b也变了!!但是在项目中,代码量比较大,代码位置分散,问题是不容易被发现的。我们可以简单的说b是一个指针,指向person.info的内存。如果我们不想让b的值变化,怎么办?

    就是重新给person.info赋值为{}后再操作!

    原理就是person.info = {};那么person.info 就指向了一块新内存,而b指向的还是之前的内容,所以再对person.info赋值就不会影响b的值了。

    最新回复(0)