javascript中clone对象详解
作者:bea
开发中,打断对象间的引用关系,只想下个副本的情况无处不在,clone一个对象就在所难免了。 JavaScript中,简单的方法就是用JSON函数,将对象stringify成字符串,再parse成一个新对象。要么就是从网上搜个代码,开源社区里面clone的代码还是有不少的。 代码虽然可以找得到,但,东西永远是别人的,动手学着码永远是个不变的主题。 自己写了两个克隆的函数: cloneOwn:克隆自定义对象的自有属性,不包括继承的属性,属性可以是基本数据类型和数组,自定
开发中,打断对象间的引用关系,只想下个副本的情况无处不在,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中,简单的方法就是用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实现获取窗口的大小和位置代码分享
- Javascript 中创建自定义对象的方法汇总
- dreamweaver 8实现Jquery自动提示
- jquery实现动态画圆
- javascript数组遍历for与for in区别详解
- 详谈nodejs异步编程
- c#+JQurey实现获取radio和checkbox的值
- express的中间件cookieParser详解
- express的中间件bodyParser详解
- express的中间件basicAuth详解
- 详解JS函数重载
- 如何让你的Lightbox支持滚轮缩放及Base64图片
- javascript常用代码段搜集
- 5种处理js跨域问题方法汇总
- 用js读、写、删除Cookie代码续篇
- 基于jquery实现等比缩放图片
- javascript简单实现图片预加载
- 3种Jquery限制文本框只能输入数字字母的方法
- javascript引擎长时间独占线程造成卡顿的解决方案