(精华)2020年6月25日 JavaScript高级篇 深拷贝和浅拷贝

举报
愚公搬代码 发表于 2021/10/19 01:03:04 2021/10/19
【摘要】 一:浅拷贝 function deep(obj){ var mn = {}; for(var key in obj) { mn[key] = obj[key] ...

一:浅拷贝

function deep(obj){
    var mn = {};
    for(var key in obj) {
        mn[key]  = obj[key]
     }   
     return  mn;      
}
var obj0 = deep(obj);
//对象
var obj1 = Object.assign({},obj);
var {...obj2} = obj;  //扩展运算符
//数组
var arr01 = [1,2,3];
arr02= arr01.slice(0);
var [...arr03] = arr01;//扩展运算符
var arr04 = Array.from(arr01);
var arr05=arr01.concat()


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

二:深拷贝

var onk1= JSON.parse(JSON.stringify(onk));//必须是单纯数据对象
//for循环递归调用
function extendDeep(source){
	var target;
	if(typeof source!='object'){
	    target = source;
	    return target;
	}
	target =  Array.isArray(source)?[]:{};
	for(var key in source){ 
	    if(typeof source[key]!='object'){
	        target[key] = source[key];
	    } else { 
	        target[key] = extendDeep(source[key])
	    }
	}
	return target;
}
var newObj2  = extendDeep(obj);


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

文章来源: codeboy.blog.csdn.net,作者:愚公搬代码,版权归原作者所有,如需转载,请联系作者。

原文链接:codeboy.blog.csdn.net/article/details/106962771

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。