深拷贝和浅拷贝

一、深浅拷贝是什么?

首先我们要明白一点,js中数据类型分为:
基本数据类型: Number, String, Boolean, Null, Undefined, Symbol
引用数据类型: Object ,Array , Function

对于引用数据 类型才有深浅拷贝的说法

1. 浅拷贝(只是拷贝了数值,或者说只是拷贝了一层数据)

代码示例1:通过Object.assign()实现

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>let obj = {name:'李白',age: 99,hobby:['足球','羽毛球'],family:{baby:'李华',father:'刘星'}}let params = Object.assign({},obj) // 得到新对象params.family.baby = '张巡'console.log('params',params);console.log('obj',obj);</script>
</body>
</html>

结果图:
在这里插入图片描述

这里明显可以看到,拷贝得到新对象params改变family的baby属性会对原对象obj的family的baby属性产生影响,就是因为他拷贝的时候复制的是原来obj里面family对象的引用地址,所以改变family的属性之后会相互影响。

代码示例2:通过es6的解构赋值也可以实现浅拷贝

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>let obj = {name:'李白',age: 99,hobby:['足球','羽毛球'],family:{baby:'李华',father:'刘星'}}let params = {...obj} // 解构赋值取值拿到新对象</script>
</body>
</html>

总结 : 通过Object.assign()或者解构赋值可以实现浅拷贝

2. 深拷贝(复制变量值,对于非基本类型的变量,则递归至基本类型变量后,再复制。 深拷贝后的对象与原来的对象是完全隔离的,互不影响,对一个对象的修改并不会影响另一个对象。)

  • 代码实现1:通过递归函数
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>let obj = {name:'李白',age: 99,hobby:['足球','羽毛球'],family:{baby:'李华',father:'刘星'}}let params = {}// 拷贝函数function deepCopy(newObj,oldObj){ // newObj:新数据,oldObj:旧数据for(let k in oldObj){if(oldObj[k] instanceof Array){ // 属性为数组newObj[k] = [] // newObj[k] --- > params.hobbydeepCopy(newObj[k],oldObj[k])}else if(oldObj[k] instanceof Object){// 属性为对象newObj[k] = {}deepCopy(newObj[k],oldObj[k])}else{ //属性为基本类型newObj[k] = oldObj[k]}}}deepCopy(params,obj) // 调用函数params.hobby[0] = '篮球'params.family.baby = '张明'console.log('params',params);console.log('obj',obj);</script>
</body>
</html>

结果图:
在这里插入图片描述
可以看到我们在params对象里面改变hobby的内容,改变family的baby属性不会对obj对象里面的内容有影响。

  • 代码实现2:通过js库的lodash里面的_.cloneDeep()

lodash官网地址

lodash.js插件下载地址

首先引入lodash插件

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- 引入插件 --><script src="../lodash.min.js"></script><script>let obj = {name:'李白',age: 99,hobby:['足球','羽毛球'],family:{baby:'李华',father:'刘星'}}let deep = _.cloneDeep(obj) // 实现深拷贝deep.family.father = '小九九'console.log('deep:',deep);console.log('obj:',obj);</script>
</body>
</html>
  • 代码实现3:利用JSON字符串转换
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>let obj = {name:'李白',age: 99,hobby:['足球','羽毛球'],family:{baby:'李华',father:'刘星'}}let str = JSON.stringify(obj)let params = JSON.parse(str) // 获取新对象params.family.baby = '赵鑫'console.log('params',params);console.log('obj',obj);</script>
</body>
</html>

总结:

  • 递归函数
  • js库的lodash里面的_.cloneDeep()
  • JSON字符串转换*

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/140818.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

中国移动集采120万部,助推国产5G赶超iPhone15

近期媒体纷纷传出消息指中国移动将大规模集采&#xff0c;预计将采购国产5G手机120万台&#xff0c;加上另外两家运营商的集采数量&#xff0c;估计集采数量可能达到300万部&#xff0c;如此将有助于它在国内高端手机市场赶超苹果。 国产5G手机在8月底突然上市&#xff0c;获益…

科技与时尚共进化,优衣库以硬实力创造品牌长期价值

时尚总是轮回&#xff0c;服装产品如何保持长青&#xff1f;对优衣库来说&#xff0c;产品力不褪色的密码之一&#xff0c;就是始终坚持推动服装科技与时尚融合&#xff0c;赋予生活潮流更多内涵&#xff0c;和更高品质的穿搭体验。 这一点&#xff0c;往往在每年换季新品上市…

Ubuntu docker安装mysql

本文介绍如何在docker中安装mysql&#xff0c;之前有尝试过先在docker中安装一个ubuntu到镜像&#xff0c;然后进去再去安装mysql相关的东西&#xff0c;发现不行&#xff0c;这边整理一下一个可行的方式。 在下载镜像的时候&#xff0c;直接下载mysql镜像。 1.搜索镜像 doc…

如何用滚动字幕丰富视频内容?只需5个步骤

视频制作需要各种元素来吸引观众的注意力&#xff0c;其中滚动字幕是一个非常实用的工具&#xff0c;可以提供背景信息&#xff0c;引导观众&#xff0c;或者作为一种装饰元素。以下是如何使用滚动字幕丰富视频内容的五个步骤&#xff1a; 1. 下载并安装适合的辅助工具 为了快速…

修炼k8s+flink+hdfs+dlink(六:学习k8s)

一&#xff1a;增&#xff08;创建&#xff09;。 直接进行创建。 kubectl run nginx --imagenginx使用yaml清单方式进行创建。 二&#xff1a;删除。 kubectl delete pods/nginx 三&#xff1a;修改。 kubectl exec -it my-nginx – /bin/bash 四&#xff1a;查看。 …

保序回归与金融时序数据

保序回归在回归问题中的作用是通过拟合一个单调递增或递减的函数&#xff0c;来保持数据点的相对顺序特性。 一、保序回归的作用 主要用于以下情况&#xff1a; 1. 有序数据&#xff1a;当输入数据具有特定的顺序关系时&#xff0c;保序回归可以帮助保持这种顺序关系。例如&…

Linux文件管理与用户管理

一、查看文件内容 1、回顾之前的命令 cat命令、tac命令、head命令、tail命令、扩展&#xff1a;tail -f动态查看一个文件的内容 2、more分屏显示文件内容&#xff08;了解&#xff09; 基本语法&#xff1a; # more 文件名称 特别注意&#xff1a;more命令在加载文件时并不…

PTA 小字辈(树)

题目 本题给定一个庞大家族的家谱&#xff0c;要请你给出最小一辈的名单。 输入格式&#xff1a; 输入在第一行给出家族人口总数 N&#xff08;不超过 100 000 的正整数&#xff09; —— 简单起见&#xff0c;我们把家族成员从 1 到 N 编号。随后第二行给出 N 个编号&#…

实时配送跟踪功能的实现:外卖跑腿小程序的技术挑战

在当今数字化时代&#xff0c;外卖和跑腿服务已经成为了生活中不可或缺的一部分。为了提供更好的用户体验&#xff0c;外卖跑腿小程序越来越注重实时配送跟踪功能的实现。这项技术挑战旨在确保顾客可以方便地跟踪他们的订单&#xff0c;以及配送员可以高效地完成送货任务。本文…

面向对象设计原则之依赖倒置原则

目录 定义原始定义进一步的理解 作用实现方法代码示例 面向对象设计原则之开-闭原则 面向对象设计原则之里式替换原则 面向对象设计原则之依赖倒置原则 面向对象设计原则之单一职责原则 定义 依赖倒置原则&#xff08;Dependence Inversion Principle&#xff09;&#xff0c…

信息系统项目管理师第四版学习笔记——组织通用管理

组织通用管理是项目管理的关键前提和基础&#xff0c;它为项目管理提供思想路线和基本原则与方法&#xff0c;项目管理则是通用管理方法在特定场景下的具体表现。 人力资源管理 人力资源管理基础 人力资源管理的广义目标是充分利用组织中的人员使组织的各项工作效率水平达到…

C++算法前缀和的应用:分割数组的最大值的原理、源码及测试用例

分割数组的最大值 相关知识点 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例&#xff1a;付视频课程 二分 过些天整理基础知识 题目 给定一个非负整数数组 nums 和一个整数 m &#xff0c;你需要将这个数组分成 m 个非空的连续子数组。 设计一个算法…