栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

js深拷贝和浅拷贝的区别

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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教程。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/14656.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号