如何用JSON.parse和JSON.stringify实现对象的深度复制?

2026-04-09 00:400阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计468个文字,预计阅读时间需要2分钟。

如何用JSON.parse和JSON.stringify实现对象的深度复制?

原文示例讲述了JS使用JSON.parse()和JSON.stringify()实现对象的深拷贝功能。以下为简化版内容:

使用JSON.parse()和JSON.stringify()可对对象进行深拷贝。例如,对不含引用对象的普通数组进行深拷贝,不复制引用对象,仅复制一。

本文实例讲述了JS使用JSON.parse(),JSON.stringify()实现对对象的深拷贝功能。分享给大家供大家参考,具体如下:

根据不包含引用对象的普通数组深拷贝得到启发,不拷贝引用对象,拷贝一个字符串会新辟一个新的存储地址,这样就切断了引用对象的指针联系。

测试例子:

var test={ a:"ss", b:"dd", c:[ {dd:"css",ee:"cdd"}, {mm:"ff",nn:"ee"} ] }; var test1 = JSON.parse(JSON.stringify(test));//拷贝数组,注意这行的拷贝方法 console.log(test); console.log(test1); test1.c[0].dd="change"; //改变test1的c属性对象的d属性 console.log(test); //不影响test console.log(test1);

测试结果:

根据测试结果,我们可以看到,test1已经从test复制一份,并且test1改变其中属性的值时,对原来的对象test没有造成影响。

阅读全文

本文共计468个文字,预计阅读时间需要2分钟。

如何用JSON.parse和JSON.stringify实现对象的深度复制?

原文示例讲述了JS使用JSON.parse()和JSON.stringify()实现对象的深拷贝功能。以下为简化版内容:

使用JSON.parse()和JSON.stringify()可对对象进行深拷贝。例如,对不含引用对象的普通数组进行深拷贝,不复制引用对象,仅复制一。

本文实例讲述了JS使用JSON.parse(),JSON.stringify()实现对对象的深拷贝功能。分享给大家供大家参考,具体如下:

根据不包含引用对象的普通数组深拷贝得到启发,不拷贝引用对象,拷贝一个字符串会新辟一个新的存储地址,这样就切断了引用对象的指针联系。

测试例子:

var test={ a:"ss", b:"dd", c:[ {dd:"css",ee:"cdd"}, {mm:"ff",nn:"ee"} ] }; var test1 = JSON.parse(JSON.stringify(test));//拷贝数组,注意这行的拷贝方法 console.log(test); console.log(test1); test1.c[0].dd="change"; //改变test1的c属性对象的d属性 console.log(test); //不影响test console.log(test1);

测试结果:

根据测试结果,我们可以看到,test1已经从test复制一份,并且test1改变其中属性的值时,对原来的对象test没有造成影响。

阅读全文