JS为什么要克隆json对象

JavaScript015

JS为什么要克隆json对象,第1张

如果你想根据一个json对象再创建一个新的对象,你可能第一时间会想到把这个json对象直接赋值给一个对象变量即可,真的如此吗?不!这个变量获得的只不过是这个json对象的指针(或者说内存地址),也就是说它们其实仍然是同一个对象,修改这个变量的某个属性值,原来的那个对象也会跟着改变,就好比一个人办了两张不同的身份证,尽管身份证不同,但持有这两张身份证的仍然是同一个人!这种情况下就要用到对象克隆了,也就是把原对象在内存中重新复制一份,然后把新的指针赋值给另一个变量,这样的话,两个对象就不再是同一个了,尽管它们内容相同,但你修改其中一个,另一个不会受其影响了。

具体做法就是新建一个空的对象,然后把原来的json对象的所有属性和方法一个个复制到新的对象中即可。

在JS中拷贝、复制一个对象的方式有多种,我常用的一般是 Object.assign({},sourceObj)。

Object.assign()因为 Object.assign()拷贝的是属性值。假如源对象的属性值是一个对象的引用,那么它也只指向那个引用。如果合并的对象是多层嵌套对象那就属于浅拷贝了,修改内层对象的值还是会影响原对象。

要想实现深度复制可以使用JSON方式。

写法如下:

它的原理是把JS对象转换为JSON字符串,再由JSON字符串转换为JS对象,这样新对象的指针就不会指向原对象的指针了。但这种也有副作用的,有一下几点副作用:

1、有属性包含时间对象,拷贝后就是字符串的形式。

2、有函数或undefined,拷贝后会丢失。

3、有RegExp和Error对象,拷贝后变为空对象。

4、存在循环引用的情况,没法正确拷贝。

5、内层对象是构造函数生成的,会丢失constructor。

6、属性值为NaN、Infinity,拷贝后变为null。

虽然有些副作用,但大多情况还是符合要求可以使用。