JS之深浅拷贝

1.深拷贝与浅拷贝的区别

如何区分深拷贝与浅拷贝,简单点来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝,拿人手短,如果B没变,那就是深拷贝,自食其力。

2.栈堆、基本数据类型、引用数据类型
栈堆:存放数据的地方
基本数据类型:number,string,boolean,null,undefined.
引用数据类型(Object类)有常规名值对的无序对象{a:1},数组[1,2,3],以及函数等。

3.浅拷贝

  let a= [0,1,2,3,4],b=a;
  console.log(a===b);
  a[0] = 1
  console.log(a,b)
image

3.深拷贝

function deepClone(obj){
    let objClone = Array.isArray(obj)?[]:{};
    if(obj && typeof obj==="object"){
        for(key in obj){
            if(obj.hasOwnProperty(key)){
                //判断ojb子元素是否为对象,如果是,递归复制
                if(obj[key]&&typeof obj[key] ==="object"){
                    objClone[key] = deepClone(obj[key]);
                }else{
                    //如果不是,简单复制
                    objClone[key] = obj[key];
                }
            }
        }
    }
    return objClone;
} 
 
let a=[1,2,3,4],b=deepClone(a);
a[0]=2;
console.log(a,b);
image

4.引用类型和基本类型栈内存储

4.1基本类型

image

4.2引用类型

image

5.JS中拷贝Array的slice和concat方法

5.1.slice拷贝

var a = [1,2,3];
var b = a.slice(); //slice
console.log(b === a);
a[0] = 4;
console.log(a);
console.log(b);
image

5.2.concat拷贝

var a = [1,2,3];
var b = a.concat();  //concat
console.log(b === a);
a[0] = 4;
console.log(a);
console.log(b);
image

看到结果,如果你觉得,这两个方法是深拷贝,那就恭喜你跳进了坑里!
来看看有意思的例子吧

var a = [[1,2,3],4,5];
var b = a.slice();
console.log(a === b);
a[0][0] = 6;
console.log(a);
console.log(b);
image

可以看到slice和contact对于第一层是深拷贝,但对于多层的时候,是复制的引用,所以是浅拷贝
6.JSON 对象的 parse 和 stringify都是深拷贝

var obj = {name:'cancan',age:23,company : { name : '阿里', address : '杭州'} };
var obj_json = JSON.parse(JSON.stringify(obj));
console.log(obj === obj_json);
obj.company.name = "cancan82";
obj.name = "haha";
console.log(obj);
console.log(obj_json);
image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • underscore 的源码中,有很多地方用到了 Array.prototype.slice() 方法,但是并没有...
    theCoder阅读 3,696评论 0 1
  • 在网上浏览了不少关于深浅拷贝的解析,在此,要总结的几点内容大致如下: 基本类型和引用类型 浅拷贝与深拷贝的区别 常...
    Weastsea阅读 3,720评论 0 3
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,793评论 1 32
  • 在使用JavaScript对数组进行操作的时候,我们经常需要将数组进行备份,事实证明如果只是简单的将它赋予其他变量...
    一木_qintb阅读 5,527评论 0 1
  • 这一章作者详细的讲解了应该怎样管理你的配置信息和在哪些情况下对你的配置信息进行修改以及怎样的配置信息是最好的状态。...
    落花的季节阅读 2,523评论 0 0