前端的深拷贝和浅拷贝_深拷贝和浅拷贝-深度解析

前言

对于 数字,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}

三、深拷贝:

方法1

JSON.stringify(obj) 先将对象转换为字符串

JSON.parse(str) 然后再将字符串转为对象。

var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};

var obj2 = JSON.stringify(obj1 );

var obj2 = 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+/"

方法2

类库的方式。jquery,lodash等库

//jquery

let y = $.extend(true,{},x) //第一个参数 必须为true

//lodash库

let y = _.cloneDeep(x);

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值