js 中的 深拷贝与浅拷贝
js在平时的项目中,赋值操作是最多的;比如说:
var person1 = {
name:"张三",
age:18,
sex:"male",
height:180,
weight:140 }
var person2 = person1;
console.log(person2)
person2.name = "李四";
console.log(person1,person2);
这段代码,console.log 打印出来的结果 person1 和person2的值是一样的。原因就是 person2 person1 都是引用类型;person2的引用地址 和person1的引用地址是一样的;所以改变person2,person1也是跟着person2 一起变化。因为改变的是同一个值。如果不明白的,可以查看https://www.cnblogs.com/lixiuming521125/p/10867062.html
那么问题来了,怎么让 person2 复制 person1的值,并且 person2改变值,不影响 person1 的值???
这里,我们可以重新创建person3,person3是个空对象;person3循环获取person1的值。即:
var person3 = {}
for(var key in person1){
person3[key] = person1[key]
}
console.log(person3);
person3.name = "王五";
console.log(person3,person1)
这里 person3 的name变成了王五,但是呢 person1的name 还是张三;
这个就是浅拷贝;
但是问题又接着出现了;
这个时候,我把person1修改了一下;增加了一个son对象;并且了,我封装了浅拷贝,把他做成了函数:
function clone(origion,target){
var tar = target?target:{};
for(key in origion){
if(origion.hasOwnProperty(key)){
tar[key] = origion[key];
}
}
return tar;
}
Object.prototype.num = 1;
var person1 = {
name:"张三",
age:18,
sex:"male",
height:180,
weight:140,
son:{
first:"lucy",
second:"joy",
third:"Jhonn"
}
}
var person4 = clone(person1);
person4.son.six = "ben"
console.log(person4,person1)
这个时候,person4的son 对象 有了这个 ben,但是 person1 的 son 对象也有。这个就是浅拷贝的一个问题,他只能拷贝 对象 数组的 引用值;
这个时候,可以通过深拷贝来解决这个问题;
//深拷贝 js原生
function deepClone(origion,target){//origion:原始数据 target:目标数据
var tar = target||{};
for(key in origion){
if(origion.hasOwnProperty(key)){
if(MyTypeOf(origion[key]) == "Array" ){
tar[key] = [];
deepClone(origion[key],tar[key]);
}else if(MyTypeOf(origion[key]) == "Object"){
tar[key] = {};
deepClone(origion[key],tar[key]);
}
tar[key] = origion[key]; }
}
return tar;
}
var person5 = deepClone(person1)
person5.son.fifth = "111111";
console.log(person5,person1)
当然还可以通过 json方式 来实现 深拷贝 JSON.stringify() JSON.parse();
var person1 = {
name:"张三",
age:18,
sex:"male",
height:180,
weight:140,
son:{
first:"lucy",
second:"joy",
third:"Jhonn"
}
};
var str = JSON.stringify(person1)//把 person1转成字符串
var json = JSON.parse(str)//把字符串转成 json对象,此时的person1 和 json实现了深拷贝
js 中的 深拷贝与浅拷贝的更多相关文章
- js 中的深拷贝与浅拷贝
在面试中经常会问到js的深拷贝和浅拷贝,也常常让我们手写,下面我们彻底搞懂js的深拷贝与浅拷贝. 在js中 Array 和 Object 这种引用类型的值,当把一个变量赋值给另一个变量时,这个值得副 ...
- js中的深拷贝与浅拷贝
对象的深拷贝于浅拷贝 对于基本类型,浅拷贝过程就是对值的复制,这个过程会开辟出一个新的内存空间,将值复制到新的内存空间.而对于引用类型来书,浅拷贝过程就是对指针的复制,这个过程并没有开辟新的堆内存空间 ...
- js中的深拷贝和浅拷贝2
所谓 深浅拷贝: 对于仅仅是复制了引用(地址),换句话说,复制了之后,原来的变量和新的变量指向同一个东西,彼此之间的操作会互相影响,为 浅拷贝. 而如果是在堆中重新分配内存,拥有不同的地址,但是值是一 ...
- JS中的深拷贝和浅拷贝
浅拷贝 浅拷贝是拷贝第一层的拷贝 使用Object.assign解决这个问题. let a = { age: 1 } let b = Object.assign({}, a) a.age = 2 co ...
- JS对象复制(深拷贝、浅拷贝)
如何在 JS 中复制对象 在本文中,我们将从浅拷贝(shallow copy)和深拷贝(deep copy)两个方面,介绍多种 JS 中复制对象的方法. 在开始之前,有一些基础知识值得一提:Javas ...
- javascript中的深拷贝与浅拷贝
javascript中的深拷贝与浅拷贝 基础概念 在了解深拷贝与浅拷贝的时候需要先了解一些基础知识 核心知识点之 堆与栈 栈(stack)为自动分配的内存空间,它由系统自动释放: 堆(heap)则是动 ...
- 浅谈Java中的深拷贝和浅拷贝(转载)
浅谈Java中的深拷贝和浅拷贝(转载) 原文链接: http://blog.csdn.net/tounaobun/article/details/8491392 假如说你想复制一个简单变量.很简单: ...
- C语言中的深拷贝和浅拷贝
//C语言中的深拷贝和浅拷贝 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #inc ...
- 浅谈Java中的深拷贝和浅拷贝
转载: 浅谈Java中的深拷贝和浅拷贝 假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(bool ...
随机推荐
- 不建议在for循环中使用”+”进行字符串拼接
https://mp.weixin.qq.com/s/qG6bdhndAip9s-_XM9oP3A 为什么阿里巴巴不建议在for循环中使用”+”进行字符串拼接 互联网后端架构 1周前
- Tomcat监听shutdown释放数据库连接池
开发时因为更新代码,频繁重启Tomcat,遇到一个问题:在执行shutdown脚本后,Tomcat进程没有关闭依然存在(但是HTTP服务已经停止),需要手动执行kill命令才行.查了一些资料结合经验, ...
- Python中的logging模块就这么用
Python中的logging模块就这么用 1.日志日志一共分成5个等级,从低到高分别是:DEBUG INFO WARNING ERROR CRITICALDEBUG:详细的信息,通常只出现在诊断问题 ...
- 第三方框架----FMDB的使用
以下是SQLite API进行封装的库FMDB的简单使用 : FMDB框架的下载地址 :https://github.com/ccgus/fmdb 代码如下 : //// ViewControlle ...
- Java使用MyBatis的ScriptRunner执行SQL脚本
脚本文件D:/test_transaction.sql: start transaction; drop table if exists testdb.test_transaction_table; ...
- Java测试当前应用所占用的内存示例
package test; import java.util.HashMap; import java.util.Map; public class TestMemory { public stati ...
- 第五章 编码/加密——《跟我学Shiro》
转发地址:https://www.iteye.com/blog/jinnianshilongnian-2021439 目录贴:跟我学Shiro目录贴 在涉及到密码存储问题上,应该加密/生成密码摘要存储 ...
- sonar:soanrqube接口api
背景: jenkins+sonar集成了代码扫描,但是发出的邮件不管项目质量是通过还是失败,每次邮件的标题都是jenkins的构建状态,所以需要获取sonar中该项目的扫描结果. 解决: 在sonar ...
- npm镜像指定用淘宝镜像去下载
使用npm下载,蜗牛,使用cnpm又觉得那啥,所以.把cnpm也就是淘宝镜像绑定成npm下载的代理,这样使用npm的时候其实是用淘宝镜像去下载,这感觉,good! 1. npm config set ...
- 图形学入门(3)——区域填充算法(region filling)
继续图形学之旅,我们已经解决了如何画线和画圆的问题,接下来要解决的是,如何往一个区域内填充颜色?对一个像素填充颜色只需调用SetPixel之类的函数就行了,所以这个问题其实就是:如何找到一个区域内的所 ...