//浅度克隆: 被拷贝的对象 和 拷贝的对象 引用值改变两者都会相应的改变
//深度克隆: 被拷贝的对象 和 拷贝的对象 引用值和原始值改变两者都不会相互影响
//浅克隆
function clone( origin , target ){
var target = target || {};
for(let prop in origin){
target[prop] = origin[prop]
}
return target;
}
clone( obj , obj1 )
// 深度克隆-步骤
// 1.判断是原始值或引用值
// 2.判断是引用值里面的对象或者数组
// 3.建立相应的对象或者数组
// 递归
function deepClone(origin,target) {
var target = target || {},
toStr = Object.prototype.toString,
arrStr = '[object Array]';
for (var prop in origin) {
if (origin.hasOwnProperty(prop) ) {//判断自身属性是否存在,不属于原型上链继承的属性
if (origin[prop] !== 'null' && typeof(origin[prop]) == 'object') {
target[prop] = toStr.call(origin[prop]) == arrStr ? [] : {} ;
deepClone(origin[prop],target[prop])
} else {
target[prop] = origin[prop];
}
}
}
return target;
}
deepClone(obj,obj1)
浅度克隆 和 深度克隆 的区别
最新推荐文章于 2023-12-17 19:03:02 发布