十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
今天小编给大家分享的是如何理解JavaScript中的深拷贝和浅拷贝,很多人都不太了解,今天小编为了让大家更加了解JavaScript中的深拷贝和浅拷贝,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。
创新互联公司专注于沁源网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供沁源营销型网站建设,沁源网站制作、沁源网页设计、沁源网站官网定制、微信小程序定制开发服务,打造沁源网络公司原创品牌,更为您提供沁源网站排名全网营销落地服务。
对于 数字,boolean 和 字符串 等基本类型 而言,赋值、浅拷贝和深拷贝无意义,因为每次都会在堆中开辟一块新的空间,指向新的地址。
一、赋值:
指向同一个地址,不拷贝。
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};
var obj2 = obj1;
obj2.name = "圆2"; //obj1中的name也会变二、浅拷贝:

var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};
var obj2 = Object.assign({},obj1);
obj2.name="圆2" // obj1.name不会变
obj2.point.x = 2 //obj1.point.x 改变,因为只拷贝到point一层
同样,解构赋值也是如此
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};
var obj2 = {…obj1}三、深拷贝:

JSON.stringify(obj) 先将对象转换为字符串
JSON.parse(str) 然后再将字符串转为对象。
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};
var obj2 = JSON.stringify(obj1 );
var obj1 = JSON.parse(obj2);
obj2.name = "圆2"; // obj1 不变
obj2.point.x = 3; // obj1 不变但JSON.stringify在转换Date,RegExp对象及function时会出现问题,同时也会忽略undefined、function。
//date 类型 var o = new Date(); console.log(o.toString()); // Mon Nov 06 2017 11:23:35 GMT+0800 (China Standard Time) 本地标准时间 console.log(JSON.stringify(o)); // "2017-11-06T03:23:35.547Z" 国际标准时间
因为stringify默认调用的是Object的toJSON方法,所以重写Date的toJSON,然后stringify就是ok的。
Date.prototype.toJSON = function () {
return this.toLocaleString();
}
console.log(JSON.stringify(o)); // "11/6/2017, 11:23:35 AM"同理RegExp
//RegExp类型
r1 = /\d+/;
console.log(JSON.stringify(r1)); // {}
RegExp.prototype.toJSON = function(){
return this.toString();
}
console.log(JSON.stringify(r1)); // "/\\d+/"类库的方式。jquery,lodash等库
//jquery
let y = $.extend(true,{},x) //第一个参数 必须为true
//lodash库
let y = _.cloneDeep(x);关于如何理解JavaScript中的深拷贝和浅拷贝就分享到这里了,当然并不止以上和大家分析的办法,不过小编可以保证其准确性是绝对没问题的。希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。