赞
踩
var obj1 = {
age: 18 };
var obj2 = obj1;//浅拷贝
obj2.age = 20;
console.log(obj1.age,obj2.age);//输出20 20
可以看到obj2的属性值改变后,obj1的属性值也改变,因为它们指向同一片内存空间
var obj1 = {
age: 18};
var obj2 = JSON.parse(JSON.stringify(obj1));//深拷贝
obj2.age = 20;
console.log(obj1.age, obj2.age); //输出18 20
与浅拷贝不同的是,深拷贝对象与原对象的内存空间是相互独立的,彼此互不干扰
*var returnTarget=object.assign(target,source);
前面可以不用写,仅仅保留Object.assign(target, source);
输出结果都是一样的,都是两个对象合并的结果
const target = {
a: 1, b: 2 };
const source = {
b: 4, c: 5 };
const returnedTarget = Object.assign(target, source);
console.
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。