码迷,mamicode.com
首页 > 其他好文 > 详细

Object克隆(深深浅浅)

时间:2017-11-21 18:02:20      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:def   return   deepcopy   深拷贝   null   support   合并   ice   throw   

  • 深度复制
    ```
    function clone(obj) {
    // Handle the 3 simple types, and null or undefined
    if (null == obj || "object" != typeof obj) return obj;

// Handle Date
if (obj instanceof Date) {
var copy = new Date();
copy.setTime(obj.getTime());
return copy;
}

// Handle Array
if (obj instanceof Array) {
var copy = [];
for (var i = 0, var len = obj.length; i < len; ++i) {
copy[i] = clone(obj[i]);
}
return copy;
}

// Handle Object
if (obj instanceof Object) {
var copy = {};
for (var attr in obj) {
if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]);
}
return copy;
}

throw new Error("Unable to copy obj! Its type isn‘t supported.");
}


- 快速复制一个数组

// 原数组
var arr = ["One","Two","Three"];
// 使用Array原型上的slice()方法
var arrtoo = arr.slice(0);
// 使用Array原型上的concat方法
var arrtooo = arr.concat();


- 对象浅拷贝(主要用于合并对象)

var obj = { a: 1 };
var copy = Object.assign({}, obj);
console.log(copy); // { a: 1 }
针对深拷贝,需要使用其他方法,因为 Object.assign()拷贝的是属性值。假如源对象的属性值是一个指向对象的引用,它也只拷贝那个引用值


- 对象的深拷贝

function deepCopy (source) {
var result={};
for (var key in source) {
result[key] = typeof source[key]===‘object‘? deepCoyp(source[key]): source[key];
}
return result;
}
```

Object克隆(深深浅浅)

标签:def   return   deepcopy   深拷贝   null   support   合并   ice   throw   

原文地址:http://www.cnblogs.com/a-xi-ba/p/7874521.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!