博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
7.JS之深浅拷贝
阅读量:5923 次
发布时间:2019-06-19

本文共 1610 字,大约阅读时间需要 5 分钟。

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] = 1console.log(a,b)

clipboard.png

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);

clipboard.png

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

4.1基本类型

clipboard.png

4.2引用类型

clipboard.png

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

5.1.slice拷贝

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

clipboard.png

5.2.concat拷贝

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

clipboard.png

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

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);

clipboard.png

可以看到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);

clipboard.png

转载地址:http://fzsvx.baihongyu.com/

你可能感兴趣的文章
《Apache Zookeeper 官方文档》-1简介
查看>>
恶补web之七:html DOM知识
查看>>
Linux备份ifcfg-eth0文件导致的网络故障问题
查看>>
第二天 web 笔记
查看>>
前端知识点总结——VUE
查看>>
2018年尾总结——稳中成长
查看>>
xampp下新增virtualhost出现access denied
查看>>
多IP主机用于挂协议挂游戏有什么好处!
查看>>
myisam和innodb区别
查看>>
C# 将字符串转换成×××、double或者date的代码
查看>>
成为高级大数据工程师的必备技能详解
查看>>
我要去做程序员,我吃得了苦
查看>>
科大讯飞,是时候考虑盈利问题了
查看>>
数字货币将对当前支付体系有什么积极的影响?
查看>>
区块链第三方支付平台:全球贸易发展先驱
查看>>
MySQL 存储过程
查看>>
我的友情链接
查看>>
windows server 2008 R2 AD 域之---IE安全设置
查看>>
PC 上的 LVM 灾难修复
查看>>
TimeRecordUtil 获取当前时间与开始时间差打印log
查看>>