详解JavaScript的内存空间、赋值和深浅拷贝(2)

var obj = { name: 'Jay Chou', age: 32, song:{ name:'发如雪', year:2007 } } var dcObj=JSON.parse(JSON.stringify(obj)); console.log(dcObj); // {name: "Jay Chou", age: 32, song: {name:'发如雪',year:2007}} console.log(dcObj.song === obj.song); //false dcObj.name='Jay'; dcObj.song.name='双截棍'; console.log(obj); // {name: "Jay Chou", age: 32, song: {name:'发如雪',year:2007}} console.log(dcObj); //{name: "Jay", age: 32, song: {name:'双截棍',year:2007}}

比较:赋值、深拷贝、浅拷贝

赋值:新对象仍然指向原对象,改变新对象的基本类型和引用类型的值都会使原对象对应的值一同改变

浅拷贝:改变新对象基本类型的值不会使原对象对应的值一起改变,但是改变新对象引用类型的值会使原对象对应的值一同改变

深拷贝:改变新对象基本类型和引用类型的值,都不会影响原对象,两者互相独立,互不影响

以上所述是小编给大家介绍的JavaScript的内存空间、赋值和深浅拷贝详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/86ce28aecf4219d7a87054fafece7bc2.html