JS深拷贝(deepClone)比较实用的两种方法

分享下js深拷贝对象,两种最常用、最实用的方法

方法1、递归遍历对象的属性,返回一个新的对象
// 这里有两种写法,都可用

const obj1 = {
	name: 'wang',
	f: function() {},
	tar: {
		name:'Jason',
		age: 18
	}
}
function deepClone(obj) {
// 写法1
	// let newObj = obj.constructor === Array ? [] : {}
	// if(typeof obj !== 'object') {
	// 	return obj
	// }else{
	// 	for(var i in obj) {
	// 		if(typeof obj[i] === 'object'){
	// 			newObj[i] = deepClone(obj[i])
	// 		}else{
	// 			newObj[i] = obj[i]
	// 		}
	// 	}
	// }
	// return newObj;
	
// 写法2
  if (!obj && typeof obj !== "object") {
    throw new Error("error arguments", "deepClone");
  }
  const targetObj = obj.constructor === Array ? [] : {};
  	Object.keys(obj).forEach(keys => {
    if (obj[keys] && typeof obj[keys] === "object") {
      targetObj[keys] = deepClone(obj[keys]);
    } else {
      targetObj[keys] = obj[keys];
    }
  });
  return targetObj;
}
var obj2 = deepClone(obj1)
console.log(obj2)

方法2:通过Object.create和Object.defineProperty取对象的所有属性,返回一个新的对象
// 方法2和方法1的区别在于,使用方法1不能拷贝对象中的时间和正则

var obj = {
  name: 'wang',
  f: function() {},
  tar: {
	name:'Jason',
	age: 18,
	cc: {
		lang: 'typescript'
	}
  },
  arr: ['11', '22'],
  reg: /\s|\n/g,
  date: new Date()
}
function deepClone(orig) {
	var copy = Object.create(Object.getPrototypeOf(orig))
	copyOwnPropertiesFrom(copy,orig);
	return copy;
}

function copyOwnPropertiesFrom(target, source) {
	Object.getOwnPropertyNames(source)
		.forEach(ele =>{
			// 获取到每个属性的所有描述,然后重新定义对象的属性并返回此对象。
			var desc = Object.getOwnPropertyDescriptor(source,ele);
			Object.defineProperty(target,ele,desc)
		});
	return target;
}
deepClone(obj)
深拷贝的方法有很多种,这里只提供两种最常用的,主要是看哪种最适用你自己
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值