js一般有两种不同数据类型的值:
基本类型(包括undefined,Null,boolean,String,Number),按值传递;
引用类型(包括数组,对象),按址传递,引用类型在值传递的时候是内存中的地址。例如
var a={"a":1};
var b=a;
b["b"]=2;
console.log(a);//{"a":1,"b":2};
如果你修改b的值,那么a变量的值也发生了变化。
克隆或者拷贝分为2种:浅度克隆(拷贝),深度克隆(拷贝);
浅度克隆:基本类型为值传递,对象仍为引用传递。
深度克隆:所有元素或属性均完全克隆,并于原引用类型完全独立,即,在后面修改对象的属性的时候,原对象不会被修改。
Object.prototype.clone = function(){
/*建立一个要空对象*/
var cloneObj;
/*如果元素的构造函数是对象就直接new 如果构造函数是STRING NUMBER等类型 因为直接NEW会得到一个默认值 所以要把原来的东西加进去*/
if(this.constructor == Object){
cloneObj = new this.constructor();
}else{
cloneObj = new this.constructor(this.valueOf());
} /*如果元素上的属性与构造的不一样,则覆盖*/
for(var i in this){
if(cloneObj[i] != this[i]){
if(typeof (this[i]) == "object"){
cloneObj[i] = this[i].clone();
}else{
cloneObj[i] = this[i];
}
}
}
/*返回两个常用的默认方法,可新增,因为toString valueof 是内置对象 无法FOR IN 例遍 CLONEOBJ里的无法比较,所以只能手动*/
cloneObj.toString = this.toString;
conleObj.valueOf = this.valueOf;
return cloneObj
}
分享到:
相关推荐
本文档是解决 引用问题的解决方案,它不仅可以解决引用值拷贝 ,还可以原样复制一个一摸一样的数组、对象包括其中的方法。
js代码-javascript深度克隆
主要介绍了JS对象的深度克隆方法,结合实例形式分析了JavaScript深度克隆的实现技巧,需要的朋友可以参考下
主要介绍了JS对象深度克隆,结合实例形式分析了JavaScript对象深度克隆的实现方法与相关注意事项,需要的朋友可以参考下
nanoclone - 只有145B实现深度克隆JavaScript对象
一个用于对象深度克隆的同构和可配置javascript函数
主要给大家介绍了关于JavaScript浅层克隆与深度克隆的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
本文将详细介绍js 深度克隆的分类与实现,需要的朋友可以参考下
主要介绍了javascript浅层克隆、深度克隆对比及实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
主要介绍了JavaScript对象之深度克隆介绍,本文详细的讲解了什么是对象深度克隆,并给出了示例代码,需要的朋友可以参考下
对象克隆ES5的深克隆和比较概要// just for conveniencevar log = function ( ) { console . log . apply ( console , [ ] . slice . call ( arguments ) ) } ; var src = { name : 'dankogai' , lang : [ 'perl' ] ...
深度克隆JavaScript 手动的: [removed][removed]代码: [removed][removed] 然后在您自己的代码中: KlonObjekt = MeineFunktionen.clone(Objekt); 或者 KlonObjekt = Objekt.clone();
omniclone用于对象深度克隆的同构和可配置的javascript函数。 omniclone(来源[,配置,[,访问者]]); 例如:const obj = {foo:{bar:'baz'}}; const obj2 = omniclone(obj); obj2; // {omniclone用于...