当前位置:网站首页>实现一个深克隆
实现一个深克隆
2022-08-10 13:07:00 【快乐的蜜蜂】
1.在js中,我们实现最快的克隆方式是什么?
没错,就是我们的
const aaa = {
"aaa": 111
}
const bbb = JSON.parse(JSON.stringify(aaa));
通过JSON.parse跟JSON.stringify方式, 可以实现深克隆的百分之80的场景,
为什么是百分之80的场景呢?
1.当对象的层级太深了,就不会安全的深克隆
2.如果对象中 含有 function 关键字,就会被转化成 “function”, 导致克隆出错
好了, 我们简单的实现一下 深克隆,很简单的几个代码
function cloneDeep(source) {
// 这里判断一下 是不是引用类型
if(typeof source != 'object') return source;
// 这里 来判断 是什么类型
let target = source.constructor == "Array" ? [] : {};
for(let key in source) {
if(source.hasOwnProperty(key)) {
if(source[key] && typeof source[key] == 'object') {
target[key] = cloneDeep(source[key]);
} else {
target[key] = source[key];
}
}
}
return target;
}
const arr1 = {
a: 1,
b: [1,2,3],
c: {
cc: 111
}
};
const arr2 = cloneDeep(arr1);
arr2.b = [1,2,3,4];
arr2.c["ddd"] = 444;
console.log(arr1, "arr1");
console.log(arr2, "arr2");
结果是:
arr2添加的数据, arr1 互不影响, 这个样子就是 简单版的深克隆就写好了
边栏推荐
- 雨水中存在的PFAS化学物质对饮用水安全构成了威胁
- CodeForces-834C
- 2022 Recruitment Notice for Academician Zhao Guoping Group of Shenzhen Institute of Advanced Technology, Chinese Academy of Sciences
- 【目标检测】小脚本:提取训练集图片与标签并更新索引
- 【MinIO】工具类使用
- 学习日记9
- Codeforces Round #276 (Div. 1) D. Kindergarten
- 一个 CRM One Order Application log 的单元测试报表
- 用低代码驱动IT现代化
- The recursive recursive Fighting_ silver study ah but level 4
猜你喜欢
随机推荐
Pod生命周期
MySQL面试题整理
一种能让大型数据聚类快2000倍的方法,真不戳
Proprietary cloud ABC Stack, the real strength!
Guidelines for Sending Overseas Mail (2)
malloc 函数详解
Redis上云迁移实践
友邦人寿可观测体系设计与落地
进程和计划任务管理
M²BEV: Multi-Camera Joint 3D Detection and Segmentation with Unified Bird’s-Eye View Representation
【iOS】Organization of interviews
LeetCode·每日一题·640.求解方程·模拟构造
DNS欺骗-教程详解
Network Saboteur
商汤自研机械臂,首款产品是AI下棋机器人:还请郭晶晶作代言
Shell:数组
3DS MAX 批量导出文件脚本 MAXScript 带界面
网络安全——XSS之被我们忽视的Cookie
Code Casual Recording Notes_Dynamic Programming_70 Climbing Stairs
【219】慕课三千多的那个go工程师的培训课笔记 02 go语言的编程思想