浅拷贝和深拷贝

浅拷贝:只能复制数值类型,引用类型无效

对象里有单个属性

let obj = {
	name:"july"
}
let obj2 = {
	name:obj.name
}

对象里有多个属性

let obj = {
	name:"july",
	age:18
}
//第一种方法
let obj1 = {}
for(const key in obj){
	obj1[key] = obj[key]
}
//第二种方法
let obj2 = Object.assign({},obj)
//第三种方法
let obj3 = {...obj}

如果对象里还套有一层对象,就只能用深拷贝了
深拷贝:不仅可以复制值类型还可以复制引用类型
用JSON字符串实现深拷贝

let data = {
	name:"july",
	user:{
		name:"jack"
	},
	arr:["july","jack"]
}
function copy(obj){
	let str = JSON.stringify(obj);
	return JSON.parse(str);
}
let person = {
	name:"july",
	father:{
		name:"yuehan"
	}
}
function copy(obj){
	let res = {};
	for(const key in obj){
		res[key] = typeof obj[key]?copy(obj[key]):obj[key]
		//因为遍历obj得到值含有对象,所以需要把得到的对象再遍历一次
	}
	return res
}

当对象中既含有对象也含有数组的时候

let person = {
	name:"july",
	father:{
		name:"yuehan"
	},
	arr:[]
}
function copy(obj){
	let res = obj instanceof Array?[]:{};
	for(const [k,v] of Object.entries(obj)){
		res[k] = typeof v =='object'?copy(v):v
	}
	return res
}

此函数还可以这样写

let person = {
	name:"july",
	father:{
		name:"yuehan"
	},
	arr:[]
}
function copy(target){
	let result;
	if(typeof targer === "object"){
		if(targer instanceof Array){
			result = [];
			for(const key in target){
				result.push = copy(target[key])
			}
		}else{
			result = {};
			for(const key in target){
				result[key] = copy(target[key])
			}
		}
	}else{
		result = target
	}
	return result
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值