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

对象复制

时间:2018-04-07 01:07:42      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:运行   body   type   gpo   keyword   func   影响   遍历   arguments   

方法一:

把原来对象的属性遍历一遍,赋给一个新的对象。

  1. //深复制对象方法    
  2. var cloneObj = function (obj) {  
  3.     var newObj = {};  
  4.     if (obj instanceof Array) {  
  5.         newObj = [];  
  6.     }  
  7.     for (var key in obj) {  
  8.         var val = obj[key];  
  9.         //newObj[key] = typeof val === ‘object‘ ? arguments.callee(val) : val; //arguments.callee 在哪一个函数中运行,它就代表哪个函数, 一般用在匿名函数中。  
  10.         newObj[key] = typeof val === ‘object‘ ? cloneObj(val): val;  
  11.     }  
  12.     return newObj;  
  13. };  
  14. //测试    
  15. var obj = {a:function(){console.log(this.b.c)},b:{c:1}},//设置一个对象  
  16. newObj = cloneObj(obj);//复制对象  
  17. newObj.b.c=2;//给新对象赋新值  
  18. obj.a();//1,不受影响  
  19. newObj.a();//2  

方法二:

将对象序列化再解析回来,对象中如果有函数function则不能正确复制

  1. var obj = {a:1,b:2}  
  2. var newObj = JSON.parse(JSON.stringify(obj));  
  3. newObj.a=3;  
  4. console.log(obj);  
  5. console.log(newObj);  

方法三:

针对数组对象的方法,用数组方法concat一个空数组

  1. var a=[1,2,3];  
  2. var b=a;  
  3. var c=[].concat(a);  
  4. a.push(4);  
  5. console.log(b);  
  6. console.log(c);  

对象复制

标签:运行   body   type   gpo   keyword   func   影响   遍历   arguments   

原文地址:https://www.cnblogs.com/looklu/p/8729481.html

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