JS对象拷贝实现

这里的对象(深)拷贝,不是对象的赋值引用。
是新建一个对象,然后通过遍历原对象,将所有的属性赋值给新的对象

//(不支持关联/索引混合的数组)
function extend(parent) {
	var child;	
	if(!isObject(parent) && !isArray(parent)) return parent;
	if(isArray(parent) && parent.length){
		child = [];	
		parent.forEach(function(item){
			child.push(extend(item));
		})
	} 
	else if(isArray(parent)&&parent.length==0){
	//关联数组
		child = [];
		handler()
	}
	else if(isObject(parent)){
		child = {};
		handler()
	}			
	return child; //返回目标对象child
	
	function handler(type){		
		for(var i in parent) {			
			//直接操作对象的属性,对其赋值
			if(parent.hasOwnProperty(i)) {
				if(isObject(parent[i]) || isArray(parent[i])){
					child[i] = extend(parent[i])
				}else{										
					child[i] = parent[i]				
				}						
			}
		}		
	}
}

注意,上面的isArray和isObject是另外定义的用来判断是否是数组和是否是对象的方法

你可能感兴趣的:(前端)