js之-实现深浅拷贝的各种方法(js深拷贝和浅拷贝的使用场景)
off999 2024-10-29 15:00 36 浏览 0 评论
在js中,数据类型分两种: ‘基本数据类型’ 和 ‘引用数据类型’
‘基本类型数据’ 存在于 栈内存 中,'引用数据类型’ 的属性存在于 栈内存中,值存在与 堆内存中,通过指针来指向对应值
所以,深浅拷贝主要出现在引用数据类型中
如下图,就是浅拷贝,拷贝出来的变量 copyArray,只是拷贝指针,指向的还是同一个堆内存中的数据,所以,其中一个值改变,另外一个值相应改变
如下图,就是深拷贝,拷贝出来的值,在堆内存中另外开辟空间,存储新值,通过指针指向。当改变新拷贝的值时,原值不会被改变。
JSON.prase( JSON.string() )
var arr = [1,2,3,4,5];
var copyArray = JSON.parse( JSON.stringify(arr) );
copyArray[0] = 0;
console.log( arr ) // [1, 2, 3, 4, 5]
console.log( copyArray ) // [0, 2, 3, 4, 5]但是 JSON.parse来转译深拷贝,真的就没问题吗?
先多层嵌套,试一下是否还能深拷贝
var arr = [1, [2,3] , {name: '1'} ];
var copyArray = JSON.parse( JSON.stringify(arr) );
copyArray[1][1] = 0;
console.log( arr ); // [1, [2,3] , {name: '1'} ]
console.log( copyArray ) ; // [1, [2,0], {name: "1"} ]从上面代码可以看出,多层嵌套时,也能深拷贝。当数据里含有function是否可以依然深拷贝?
var obj = { name: "1" , f: function(){ alert(1) } };
var copyObj = JSON.parse( JSON.stringify(obj) );
console.log( obj ); // {name: "1", f: ?}
console.log( copyObj ) ; // {name: "1"}从上面代码可以总结出:
JSON.parse进行深拷贝时,能够满足部分数据需求,能够进行多层次数据的拷贝,但是会忽略function,undefined,symbo,所以在使用时,要注意数据结构
循环递归深拷贝
function copy( obj ){
// 定义常量
const newCopy = obj.constructor === Array ? [] : {};
// 循环数据
for( var key in obj ){
// 判断是否有这个变量
if( obj.hasOwnProperty(key) ){
// 判断当前属性是否有值,并且属不属于Array和object (typeOf,不管array还是object都返回object)
if( !!obj[key] && typeof obj[key] === 'object' ){
// 属于Array或者object,并且有值,调用自身,重新循环
newCopy[key] = copy(obj[key]);
}else {
// 不属于或者没值,直接赋值
newCopy[key] = obj[key]
}
}
}
// return出深拷贝数据
return newCopy;
};
// 调用一下
var demoObj = {
name: {
val:"1",
val2:"2",
val3:"3"
} ,
arr: [1,2,3,4],
f: function(){ alert(2) }
}
var cloneDemoObj = copy(demoObj);
cloneDemoObj.f = function(){
alert(6);
}
demoObj.f(); // 弹出2
cloneDemoObj.f(); // 弹出6
cloneDemoObj.arr[0] = 6;
cloneDemoObj.name.val = "6";
console.log( demoObj ); // {name: {val:"1",val2:"2",val3:"3"} , arr: [1,2,2,4], f:f{} }
console.log( cloneDemoObj); // {name: {val:"6",val2:"2",val3:"3"} , arr: [6,2,2,4], f:f{} }concat() , slice(),都不改变原数组,新建数据,经测试,只能深拷贝首层数据
var arr = [1,2,3];
var copyArr = arr.concat();
copyArr[0] = 2;
console.log( arr ); // [1, 2, 3]
console.log( copyArr ); // [2, 2, 3]
var arr1 = [1, [1,1,1], 2];
var copyArr1 = arr1.concat();
copyArr1[0] = 0;
copyArr1[1][0] = 0; //深层次数据没有深拷贝,被改变,如下
console.log( arr1 ); // [1, [0,1,1], 2];
console.log( copyArr1); // [0, [0,1,1], 2];相关推荐
- adobe indesign(adobe indesign 下载)
-
在InDesign中,您可以通过使用数据合并功能来快速导入全年日历。首先,您需要准备一个包含所有日期和相应格式的数据表格,然后在InDesign中创建一个日历模板。接下来,使用数据合并功能将数据表格与...
- qq32位版本下载官方(qq3.3.3版本下载)
-
1152活跃天。QQ等级升级需要的活跃天数和自然的日是完全不同的,活跃天并不等于自然天数。活跃天是需要满足加速条件后才能获得的,相当于某些业务的成长值,经验值等,QQ等级由四个标识图展示,从低到高分别...
- 最新版本qq手机版下载安装免费
-
你说的是下载QQ软件吗?现在手机应用市场里都有QQ软件下载的,或者直接百度也可以。不用。苹果手机在appstore里下载手机qq步骤如下:1.在苹果手机中打开自带的AppStore软件进入;2.按...
- 全国34个卫视频道(全国34个卫视频道节目单)
-
全国卫视频道不止34个。全国各地28大省级卫视:北京卫视·天津卫视·河北卫视·山西卫视·内蒙古卫视·辽宁卫视·吉林卫视·黑龙江卫视·江苏卫视·浙江卫视·安徽卫视·江西卫视·山东卫视·河南卫视·湖北卫视...
- 福昕pdf阅读器电脑版(福昕pdf阅读器电脑版怎么用)
-
这是因为你的pdf文件没有与福昕阅读器进行关联。你如果要想双击pdf文档后使用福昕阅读器打开,可以这样设置一下::选中pdf文档,右击鼠标,在快捷菜单中点击属性。点击“属性”对话框中“打开方式”右边的...
- 快吧游戏官网(快吧游戏中心)
-
1.快吧游戏可以通过官方网站或应用商店进行下载。2.官方网站提供了游戏的下载链接,也可以通过扫描二维码进行下载。快吧游戏是一款手机游戏,可以在应用商店中下载安装。以下是在iOS和Android系统...
- 最开放的浏览器下载(最开放的浏览器下载软件)
-
可以直接在浏览器设置内打开下载目录进行查看,步骤如下:所需材料:华为6X、华为浏览器示例。一、因为所有浏览器的设置基本一至,这里以华为浏览器为例,首先点击打开华为浏览器。二、打开浏览器后,点击右下角的...
- 万年历2025最新版(万年历2025最新版属相)
-
2024年正月初十对应的阳历出生日期是2024年2月1日。如果按照周岁来计算,他们属龙。辰龙(甲辰年):在中国传统文化中,龙象征着权力、尊贵和神圣。
- 163邮箱登录网页版(163邮箱登录网页版官网)
-
http://mail.163.com步骤一:输入邮箱官网网址http://mail.163.com/打开163邮箱登录入口界面。步骤二:输入已有的邮箱账号、密码,点击登录即可。步骤三:如果没有邮箱账...
- 青骄第二课堂学生登录入口(青骄第二课堂,登录入口)
-
青骄第二课堂学生账号注册是不需要学生注册的,是经过每个学校的老师就是班主任注册之后,学生才能登录首先我们要打开自己的微信,点击打开微信右上方的加号点击添加好友,点击公众号,搜索青椒第二课堂点...
- 视频剪辑器(视频剪辑器在线使用)
-
推荐4款常用的视频剪辑软件吧:大众级别的:剪大师、会声会影专业级别的:AdobePremiere、EDIUS先介绍大众级别的吧:一:剪大师?自动关键帧动画技术,多轨逐帧精确剪辑,制作精彩动画影片?...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
