JS深拷贝之解决object数组对象值、址指向同一个

js深拷贝

应用场景
1、JavaScript中,Object是引用类型,把对象A赋值给B之后,改变B的值,A会跟着改变。这是因为默认执行浅拷贝,也就是在内存中只复制了一个指针给了B,内存中的数据本身并没有被复制。

  • 方法一
const clone = {...original}

实例

//这种方式只能用于单层json对象,也就是对象中的每个value都是基本类型,没有嵌套。
let A = {name: zhangsan}
let B = {...A}
b.name= lisi
console.log(a) // {name: zhangsan}
  • 方法二
const clone = Object.assign({}, original)

实例

var A = { name: zhangsan };
var B = Object.assign({}, A);
B.A -= name = lisi
console.log(A) // {name: lisi}
  • 方法三
//这个是可以对多层json对象进行拷贝的
let B = JSON.parse(JSON.stringify(A));

实例:(复制数组)

//用json.parse和json.stringify复制一个新的数组
jsonTransfer(obList){
        let tempOb = null;
        if(typeof (obList) == 'object') {//为数组类型先stringify再parse
          tempOb = JSON.parse(JSON.stringify(obList));
        } else if(typeof (obList) == 'string') { //为json格式时直接parse转
          tempOb = JSON.parse(obList);
        }
        return tempOb;
      },
addNewData(index, row) {
	let data = [{name: '张三', age: 18},{name: '李四', age: 90}];
	this.temp1 = this.jsonTransfer(data);//[{name: '张三', age: 18},{name: '李四', age: 90}];
	this.temp2 = this.jsonTransfer(data);//[{name: '张三', age: 18},{name: '李四', age: 90}];
	this.temp1 = [{name: '王五', age: 12}];
	//this.temp2的值是[{name: '张三', age: 18},{name: '李四', age: 90}];
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值