码迷,mamicode.com
首页 > Web开发 > 详细

js 深拷贝

时间:2019-09-28 14:42:04      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:one   ===   name   ||   技术   eof   递归   var   ret   

技术图片

 

 技术图片

 

 


Object.prototype.num = 1; // 原型链顶端
var person1 = {
   name: ‘ytao‘,
   age: 18,
   sex: ‘male‘,
   height: 165,
   weight: 100,
   children: {
     first:{
       name: ‘张小一‘,
       age: 13
     },
     second:{
       name: ‘张小二‘,
       age: 12
     },
     third:{
       name: ‘张小三‘,
       age: 11
     },
   },
   car: [‘Benz‘, ‘Mazda‘]
 }

var person2 = deepClone(person1, person2);
person2.name = ‘lisi‘;
person2.children.forth = {
  name: ‘张小四‘,
  age: 1
};
person2.car.push(‘BYD‘);


// 深拷贝
function deepClone(origin, target){
  var target = target || {},
      toStr = Object.prototype.toString,
      arrType = ‘[object Array]‘;
  for(var key in origin){
    if(origin.hasOwnProperty(key)){
      if(typeof(origin[key]) === ‘object‘ && origin[key] !== null){
        if(toStr.call(origin[key]) === arrType){
          target[key] = [];
        } else {
          target[key] = {};
        }
        deepClone(origin[key], target[key]); // 递归处理
      }else{
       target[key] = origin[key];
      }
    }
  }
  return target;
}

console.log(person1);
console.log(person2);

js 深拷贝

标签:one   ===   name   ||   技术   eof   递归   var   ret   

原文地址:https://www.cnblogs.com/yrqingblog/p/11602896.html

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