浅谈JavaScript中面向对象的的深拷贝和浅拷贝
理解深拷贝和浅拷贝之前需要弄懂一些基础概念,内存中存储的变量类型分为值类型和引用类型。
1、值类型赋值的存储特点, 将变量内的数据全部拷贝一份, 存储给新的变量。
例如:var num = 123 ;var num1=num;
表示变量中存储的数字是 123。然后将数据拷贝一份,就是将 123 拷贝一份. 那么内存中有 2 个 数组;将拷贝数据赋值给 num2,其特点是在内存中有两个数据副本.这可以理解为浅拷贝。
2、引用类型的赋值。
var o={name:'张三‘};
var obj=o;
赋值就是将 变量 o 中存储的数据拷贝一份, 然后将该数据赋值给 obj。内存中有 1 分数据,利用 obj 修改的 name 属性会影响到 o 中的 name。
如果拷贝的时候, 将数据的所有引用结构都拷贝一份, 那么数据在内存中独立就是深拷贝;
如果拷贝的时候, 只针对当前对象的属性进行拷贝, 而属性是引用类型这个不考虑, 那么就是浅拷贝;
拷贝: 复制一份. 指将对象数据复制;
在讨论深拷与浅拷的时候一定要保证对象的属性也是引用类型。
以上这篇浅谈JavaScript中面向对象的的深拷贝和浅拷贝就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
- Javascript 浅拷贝、深拷贝的实现代码
- JavaScript数组深拷贝和浅拷贝的两种方法
- js对象浅拷贝和深拷贝详解
- javascript对浅拷贝和深拷贝的详解
- javascript深拷贝和浅拷贝详解
- 浅析javaScript中的浅拷贝和深拷贝
- JavaScript基础心法 深浅拷贝(浅拷贝和深拷贝)
- javascript深拷贝、浅拷贝和循环引用深入理解
- JavaScript深拷贝和浅拷贝概念与用法实例分析
- JavaScript实现浅拷贝与深拷贝的方法分析
- JS浅拷贝和深拷贝原理与实现方法分析
- JS中实现浅拷贝和深拷贝的代码详解
- javascript二维数组和对象的深拷贝与浅拷贝实例分析
- javascript 关于赋值、浅拷贝、深拷贝的个人理解
- JS赋值、浅拷贝和深拷贝(数组和对象的深浅拷贝)实例详解
- 详解JS深拷贝与浅拷贝
- JS对象复制(深拷贝和浅拷贝)
- js深拷贝与浅拷贝一文彻底搞懂
最新评论