javascript中clone對(duì)象詳解
開發(fā)中,打斷對(duì)象間的引用關(guān)系,只想下個(gè)副本的情況無處不在,clone一個(gè)對(duì)象就在所難免了。
JavaScript中,簡單的方法就是用JSON函數(shù),將對(duì)象stringify成字符串,再parse成一個(gè)新對(duì)象。要么就是從網(wǎng)上搜個(gè)代碼,開源社區(qū)里面clone的代碼還是有不少的。
代碼雖然可以找得到,但,東西永遠(yuǎn)是別人的,動(dòng)手學(xué)著碼永遠(yuǎn)是個(gè)不變的主題。
自己寫了兩個(gè)克隆的函數(shù):
cloneOwn:克隆自定義對(duì)象的自有屬性,不包括繼承的屬性,屬性可以是基本數(shù)據(jù)類型和數(shù)組,自定義的對(duì)象,可以制定要克隆的屬性名稱列表。
cloneArray: 克隆數(shù)組,數(shù)組內(nèi)的元素可以是對(duì)象,基本類型。
//第一個(gè)參數(shù)是被克隆的對(duì)象,第二個(gè)參數(shù)是需要克隆的屬性列表
function cloneOwn() {
var obj = arguments[0];
if (typeof obj === 'undefined' || obj === null)
return {};
if (typeof obj !== 'object')
return obj;
//第二個(gè)參數(shù)是屬性名稱列表,就采用該列表進(jìn)行刷選
//否則就克隆所有屬性
var attrs = arguments[1];
var enable_spec_attr = true;
if (!(attrs instanceof Array)) {
//console.log(attrs);
attrs = obj;
enable_spec_attr = false;
}
var result = {};
var i;
for (i in attrs) {
attr = enable_spec_attr? attrs[i]: i;
//console.log(attr);
if (obj.hasOwnProperty(attr)) {
if (obj[attr] instanceof Array) {
result[attr] = cloneArray(obj[attr]);
}
else if (typeof obj[attr] === 'object') {
result[attr] = cloneOwn(obj[attr]);
} else {
result[attr] = obj[attr];
}
}
}
return result;
}
//克隆數(shù)組
function cloneArray(array) {
if (typeof array === 'undefined' || array === null)
return [];
if (!(array instanceof Array))
return [];
result = [];
var i;
for(i in array) {
if (typeof array[i] !== 'object') {
result[i] = array[i];
continue;
}
//clone object
result[i] = cloneOwn(array[i]);
}
return result;
}
調(diào)用
1.常規(guī)克隆自定義對(duì)象:
var a = {
name:'frank',
age:20
};
var b= cloneOwn(a);
2.指定克隆的屬性
var a = {
name:'frank',
age:20,
address:'any where'
};
var b = cloneOwne(a, ['name', 'age']);
3.克隆內(nèi)含有數(shù)組屬性的自定義對(duì)象
var a = {
name: 'kxh',
age: 20,
books: ['hai','ho','ali'],
likes: [
{wname: 'kaili', wage: 81, fav: "aaaaa"},
{wname: 'seli', wage: 82, fav: "bbb"},
{wname: 'ailun', wage: 83, fav: "ccc"},]
};
var b = cloneOwne(a);
4.克隆數(shù)組,內(nèi)含有自定義對(duì)象
var a = [
{
name:'frank',
age:20
},
{
name:'leon',
age:30
}
];
var b = cloneArray(a);
上面的代碼還是有很多問題的,比如,內(nèi)置對(duì)象的克隆就存在點(diǎn)問題,例如datatime類型。
問題管問題,這樣一個(gè)學(xué)習(xí)過程也是要有的。
- 原生js實(shí)現(xiàn)復(fù)制對(duì)象、擴(kuò)展對(duì)象 類似jquery中的extend()方法
- JavaScript驗(yàn)證圖片類型(擴(kuò)展名)的函數(shù)分享
- JavaScript 深層克隆對(duì)象詳解及實(shí)例
- js克隆對(duì)象、數(shù)組的常用方法介紹
- javascript克隆對(duì)象深度介紹
- Javascript Object.extend
- JavaScript Object的extend是一個(gè)常用的功能
- JavaScript 用cloneNode方法克隆節(jié)點(diǎn)的代碼
- JS擴(kuò)展類,克隆對(duì)象與混合類實(shí)例分析
相關(guān)文章
window.showModalDialog使用手冊(cè)
window.showModalDialog使用手冊(cè)...2007-01-01javascript數(shù)據(jù)代理與事件詳解分析
所謂數(shù)據(jù)代理(也叫數(shù)據(jù)劫持),指的是在訪問或者修改對(duì)象的某個(gè)屬性時(shí),通過一段代碼攔截這個(gè)行為,進(jìn)行額外的操作或者修改返回結(jié)果。比較典型的是 Object.defineProperty() 和 ES2015 中新增的 Proxy 對(duì)象2021-11-11javaScript中"=="和"==="的區(qū)別詳解
對(duì)于JavaScript中比較運(yùn)算符,可能大家用的比較多的是“==”、對(duì)于“===”很多人可能很陌生。=== 表示恒等,首先比較兩邊的變量數(shù)據(jù)類型是否相等,其次比較兩邊的變量的數(shù)值是否相等;== 表示相等即僅僅比較兩邊變量的數(shù)值是否相等。2018-03-03js 實(shí)現(xiàn)復(fù)制到粘貼板的功能代碼
主要是用到了 window.clipboardData.setData("Text",copyText);2010-05-05JavaScript Try...Catch 聲明的 使用方法
JavaScript Try...Catch 聲明的 使用方法...2007-04-04JavaScript 學(xué)習(xí)筆記 Black.Caffeine 09.11.28
這兩天終于寫出了一個(gè)個(gè)人認(rèn)為真正意義上的作業(yè)了,不過,最大感受就是。。。IE太垃圾了。。。so,這個(gè)作業(yè)實(shí)際上也沒有完成的很完美,因?yàn)?,在IE上還是有兼容性的問題存在,不錯(cuò),就此先自我總結(jié)一下吧~免得以后又忘了~2009-11-11張孝祥JavaScript學(xué)習(xí)階段性總結(jié)(2)--(X)HTML學(xué)習(xí)
張孝祥JavaScript學(xué)習(xí)階段性總結(jié)(2)--(X)HTML學(xué)習(xí)...2007-02-02