超级计算机囧囧囧's Archivers

From admin on 2014-04-28 10:15:54

实现JS对象的克隆

在js里没有类似JAVA的clone方法,无法实现对对象的克隆,一般使用等号操作符来传递对象,但这样就造成了指针关联问题,修改任何一个对象,其关联的对象也会被改变,但很多时候我们只想得到一个对象的拷贝,而非引用。今日偶就遇到了这个问题,以前还真没有注意过这个,朋友给找了两个方法,感觉写的都不错。只是实现稍有不同,但大体原理是相对的,即逐项复制对象内容。
相信这段代码对很多web开发的朋友都会有用。

方法一:定义一个clone方法来实现。
function clone(myObj) {
if (typeof(myObj) != 'object') return myObj;
if (myObj == null) return myObj;
var myNewObj = new Object();

for (var i in myObj) myNewObj[i] = clone(myObj[i]);

return myNewObj;
}
方法二:通过object原型扩展实现
Object.prototype.Clone = function() {
var objClone;
if (this.constructor == Object) objClone = new this.constructor();
else objClone = new this.constructor(this.valueOf());
for (var key in this) {
if (objClone[key] != this[key]) {
if (typeof(this[key]) == 'object') {
objClone[key] = this[key].Clone();
} else {
objClone[key] = this[key];
}
}
}
objClone.toString = this.toString;
objClone.valueOf = this.valueOf;
return objClone;
}

查看完整版本: 实现JS对象的克隆

Tags:


©超级计算机囧囧囧