感覺這個題目涉及的基礎(chǔ)知識內(nèi)容比較多庐扫,故分享出來锋玲,后面會詳細(xì)介紹數(shù)據(jù)類型的文章蜗字,歡迎關(guān)注汤徽。
實現(xiàn)一個函數(shù)clone娩缰,可以對JavaScript中的5種主要的數(shù)據(jù)類型(包括Number、String谒府、Object拼坎、Array浮毯、Boolean)進行值復(fù)制。
/**
* 對象克隆
* 支持基本數(shù)據(jù)類型及對象
* 遞歸方法
*/
function clone(obj) {
var o;
switch (typeof obj) {
case "undefined":
break;
case "string":
o = obj + "";
break;
case "number":
o = obj - 0;
break;
case "boolean":
o = obj;
break;
case "object": // object 分為兩種情況 對象(Object)或數(shù)組(Array)
if (obj === null) {
o = null;
} else {
if (Object.prototype.toString.call(obj).slice(8, -1) === "Array") {
o = [];
for (var i = 0; i obj.length; i++) {
o.push(clone(obj[i]));
}
} else {
o = {};
for (var k in obj) {
o[k] = clone(obj[k]);
}
}
}
break;
default:
o = obj;
break;
}
return o;
}
如果你有高級前端的水平泰鸡,這個時候就應(yīng)該寫出下面的代碼
Object.prototype.clone = function(){
var o = this.constructor === Array ? [] : {};
for(var e in this){
o[e] = typeof this[e] === "object" ? this[e].clone() : this[e];
}
return o;
}
基礎(chǔ)知識還需要牢固债蓝,要不怎么能寫出這樣高端的寫法呢?哈哈??