手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript中clone对象详解
javascript中clone对象详解
摘要:开发中,打断对象间的引用关系,只想下个副本的情况无处不在,clone一个对象就在所难免了。JavaScript中,简单的方法就是用JSON函...

开发中,打断对象间的引用关系,只想下个副本的情况无处不在,clone一个对象就在所难免了。

JavaScript中,简单的方法就是用JSON函数,将对象stringify成字符串,再parse成一个新对象。要么就是从网上搜个代码,开源社区里面clone的代码还是有不少的。

代码虽然可以找得到,但,东西永远是别人的,动手学着码永远是个不变的主题。

自己写了两个克隆的函数:

cloneOwn:克隆自定义对象的自有属性,不包括继承的属性,属性可以是基本数据类型和数组,自定义的对象,可以制定要克隆的属性名称列表。

cloneArray: 克隆数组,数组内的元素可以是对象,基本类型。

复制代码 代码如下:

//第一个参数是被克隆的对象,第二个参数是需要克隆的属性列表

function cloneOwn() {

var obj = arguments[0];

if (typeof obj === 'undefined' || obj === null)

return {};

if (typeof obj !== 'object')

return obj;

//第二个参数是属性名称列表,就采用该列表进行刷选

//否则就克隆所有属性

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;

}

复制代码 代码如下:

//克隆数组

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;

}

调用

1.常规克隆自定义对象:

复制代码 代码如下:

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.克隆内含有数组属性的自定义对象

复制代码 代码如下:

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.克隆数组,内含有自定义对象

复制代码 代码如下:

var a = [

{

name:'frank',

age:20

},

{

name:'leon',

age:30

}

];

var b = cloneArray(a);

上面的代码还是有很多问题的,比如,内置对象的克隆就存在点问题,例如datatime类型。

问题管问题,这样一个学习过程也是要有的。

【javascript中clone对象详解】相关文章:

JavaScript中的私有成员

JavaScript中的this,call,apply使用及区别详解

javascript匹配车牌号正则表达式

javascript清空table表格的方法

详解JavaScript中void语句的使用

JavaScript Date对象详解

JavaScript中的Math.sin()方法使用详解

javascript事件冒泡实例分析

JavaScript事件的理解

javascript中CheckBox全选终极方案

精品推荐
分类导航