深拷⻉浅拷⻉的区别?如何实现⼀个深拷⻉?

JavaScript 中存在两⼤数据类型:

  •  基本类型
  •  引⽤类型

基本类型数据保存在在栈内存中

引⽤类型数据保存在堆内存中,引⽤数据类型的变量是⼀个指向堆内存中实际对象的引⽤,存在栈中

浅拷⻉

浅拷⻉,指的是创建新的数据,这个数据有着原始数据属性值的⼀份精确拷⻉ 如果属性是基本类型,拷⻉的就是基本类型的值。如果属性是引⽤类型,拷⻉的就是内存地址 即浅拷⻉是拷⻉⼀层,深层次的引⽤类型则共享内存地址 下⾯简单实现⼀个浅拷⻉ 

在 JavaScript 中,存在浅拷⻉的现象有:

  •  Object.assign
  • Array.prototype.slice() ,Array.prototype.concat()
  • 使⽤拓展运算符实现的复制

Object.assign 

slice() 

concat() 

拓展运算符 

深拷⻉ 

深拷⻉开辟⼀个新的栈,两个对象属完成相同,但是对应两个不同的地址,修改⼀个对象的属性,不会 改变另⼀个对象的属性

常⻅的深拷⻉⽅式有:

  • _.cloneDeep()
  • jQuery.extend()
  • JSON.stringify()
  • ⼿写循环递归 

_.cloneDeep() 

jQuery.extend()

JSON.stringify() 

但是这种⽅式存在弊端,会忽略 undefined 、 symbol 和 函数

循环递归 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值