技术文章 > Web开发 >  JavaScript > 正文

js深拷贝和浅拷贝的区别

宋宋大人

在JavaScript中,变量的类型有基本类型和引用类型两种类型。我们对基本类型的复制操作是对值进行拷贝,对引用类型的复制则是拷贝地址。这中间都是通过深拷贝与浅拷贝实现的。那二者有什么区别呢?本文想做介绍。

深拷贝:

1、将数据中所有的数据赋值过去,无限层级拷贝,,每一级别的数据都会拷贝出来;

2、所有元素或属性均完全复制,与原对象完全脱离;

3、在堆中重新分配内存, 将源对象的各个属性复制进去.;

4、拷贝后,修改拷贝后的对象,不影响之前的对象。

function test(obj){
    let _obj = JSON.stringify(obj),
    objClone = JSON.parse(_obj);
    return objClone
}
var tal = {name:'lili'};
Cal=test(tal);
Cal.name = 'kiki';
console.log(tal,Cal);  //{name: "lili"} {name: "kiki"}

浅拷贝:

1、将原有的数据赋值过去,只进行一层拷贝,深层次的对象级别的就拷贝引用;

2、原始类型为值传递,对象类型仍为引用传递。;

3、是拷贝引用, 拷贝后的引用都是指向同一个存放数据位置的指针,;

4、拷贝后,修改拷贝后的对象,会影响拷贝前的对象。

var a = [1,2,3,4,5];
var b = a;
a[0] = 6;
console.log(a,b);
//代码运行结果:a:[6,2,3,4,5]  b:[6,2,3,4,5]

以上就是JavaScript中深拷贝和浅拷贝的区别,但是无论是浅拷贝还是深拷贝,一般都用于操作Object 或 Array之类的复合类型,不要忘记哦~更多js学习推荐:js教程

免费视频教程
本文原创发布python学习网,转载请注明出处,感谢您的尊重!
相关文章
 Python中Selenium库如何调用浏览器?
 python如何实现工作表合并?
 Python异常输出美化工具PrettyErrors如何使用?
 python中pandas_datareader库怎么用?
相关视频章节
 Python蟒蛇绘制代码分析
 Python概述
 解决提示“‘python’不是内部或外外部命令
 python代码缩进
 python命名规范
 《Python程序设计》课程导论
视频教程分类