JS 浅拷贝和深拷贝

文章开始前。我们必须要知道的是 深浅拷贝是针对于引用数据而言的,对于基本数据类型并没有深浅拷贝的区分。希望此文章 能帮助到有需要的小伙伴

深浅拷贝区别:

浅拷贝:仅仅是指向被拷贝的内存地址,如果原地址中对象被改变了,那么浅拷贝出来的对象也会相应改变。
深拷贝:在计算机中开辟了一块新的内存地址用于存放复制的对象。

1.数据类型:(2种)
基本类型:String、Number、 Boolean、Null、 Undefined、Symbol(ES6新增)
引用类型:Array、Object、Function

2.浅拷贝:
浅拷贝的意思是只复制了对象的引用(指针or地址),并未复制真正的对象实体

//基本类型
var a = 1;
var b = a;
a = 2;
console.log(a,b) // 2,1; a b 指向不同的数据
//引用类型
var a = {num:1};
var b = a;
a.num = 2;
console.log(a,b)//{num:2}  a 和b 指向的是同一份数据

对于引用数据类型,会导致a ,b 都指向同一个数据。如果对其中一个进行修改。另外一个也会被修改。这不是我们想要的结果。可能还会造成不必要的BUG。如何避免这样的情况呢 我们可以用深拷贝的方式;不过我们还是先看下浅拷贝的一些方式吧;

浅拷贝的方式:

1.1 Object.assign()
var a = {num:1};
var b = Object.assign({},a);
b.num =2;
console.log(a) //{num:1}
console.log(b) //{num:2}

上述结果并未改变原对象对吧。为什么我还归类在浅拷贝方法呢。因为当数据结构只有一层的时候是深拷贝,当时多层的时候便是浅拷贝了,试一下吧

var a = {num:1,age:{age:33}};
var b = Object.assign({},a);
b.age.age =22;
console.log(a) // {num:1,age:{age:22}};
console.log(b) // {num:1,age:{age:22}};

原对象是被修改了所以明白了吧。

1.2 slice :方法可从已有的数组中返回选定的元素。
var a = [1,2,3,4];
var b = a.slice()
b[2] = 100;
console.log(a) // [1,2,3,4]
console.log(b) // [1,100,3,4]

和Object.assign()一样当是一层数据的时候是深拷贝。多层则是浅拷贝;

var a = [1,[1,3,4],{a:1}];
var b = a.slice();
b[1].psuh(100);
b[2].a = 100;
console.log(a)  //[1,[1,3,4,100],{a:100}];
console.log(b) //[1,[1,3,4,100],{a:100}];
1.3 concat :方法用于连接两个或多个数组。

再说最后一个吧.和上面几个都是一样的。是不是自己试一下

var  a= [1,2,3,4];
var b = a.concat();
b[1=100];
console.log(a) // [1,2,3,4];
console.log(a)// [1,100,3,4];
多层的自己测试一下吧

2.深拷贝

常用的深拷贝方式:

2.1 JSON.stringify/parse的方法
var a = {name:1,age:18};
var b = JSON.parse(JSON.stringify(a)); // {name:1,age:18}
a.age = 20;
console.log(a)//{name:1,age:20};
console.log(b)//{name:1,age:18};

确实是深拷贝,也很方便。但是,这个方法只能适用于一些简单的情况。比如下面这样的一个对象就不适用:

var a = {name:1, sya:function(){ console.log("打印")},age:undefined}; //{name:1,sya:f}
var b = JSON.parse(JSON.stringify(a)); // {name:1}

这样会发现有属性丢失了。原因呢MDN给出的解释:undefined、function、symbol 会在转换过程中被忽略。(对于这个大家就不要纠结了)。如果对象中含有以上类型),就不能用这个方法进行深拷贝。

2.2 递归

递归的实现逻辑,就是对每一层的数据都实现一次 创建对象->对象赋值 的操作,代码如下:

function deepClone(source){
  // 判断复制的目标是数组还是对象
  const targetObj = source.constructor === Array ? [] : {}; 
  for(let keys in source){ // 遍历目标
    if(source.hasOwnProperty(keys)){
      if(source[keys] && typeof source[keys] === 'object'){ 
        targetObj[keys] = source[keys].constructor === Array ? [] : {};
        targetObj[keys] = deepClone(source[keys]);
      }else{ // 如果不是,就直接赋值
        targetObj[keys] = source[keys];
      }
    } 
  }
  return targetObj;
}
//测试一下
var a = {name:1, sya:function(){ console.log("打印")},age:undefined}; 
var b = deepClone(a);
b.name=2;
console.log(a)//{name:1,sya:f,age:undefined}
console.log(b)//{name:2,sya:f,age:undefined}

文章是参考网上到处搜刮过来的。参考类型链接1链接2

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351