【JS】(数组、对象)深拷贝函数的封装

 1 function deepClone (obj) {
 2     let newObj;
 3     if (Array.isArray(obj)) { // 判断复制的目标是不是数组
 4         newObj = []; 
 5     } else if (typeof obj === 'object') { 
 6         newObj = {}; 
 7     } else { 
 8         newObj = obj; 
 9     }; 
10     if (typeof obj === 'object') { 
11         for (item in obj) { 
12             if(obj.hasOwnProperty(item)) { 
13                 if(obj[item] && typeof obj[item] === 'object') { 
14                     newObj[item] = deepClone(obj[item]) 
15                 } else { 
16                     newObj[item] = obj[item] 
17                 } 
18             } 
19         } 
20     } 
21     return newObj; 
22 } 
23 let obj = {name:'小明',age:20} 
24 newObj = deepClone(obj)    

当然,用JSON对象的parse和stringify也能完成深拷贝,但是用JSON.parse(JSON.stringify(obj))拷贝会有一个问题,就是如果数组或者对象中的属性为undefined、function和symbol时,转换过程中会被忽略

例:const obj = {name:'小明',age:20,subject:{a:100,b:null,c:undefined}}

  const newObj = JSON.parse(JSON.stringify(obj))

  console.log(newObj) // {name:'小明',age:20,subject:{a:100,b:null}}

 

 

posted @ 2019-01-22 16:43  小灬和灬尚  阅读(821)  评论(0编辑  收藏  举报