简述:JavaScript的深拷贝和浅拷贝大家都比较熟悉,今天来分享下深拷贝,就是使用该函数时,会复制拷贝一份该数据,修改该数据属性,不会改变原有数据,就是把复制的对象所引用的对象全都复制了一遍,具体实现如下;
1、定义拷贝对象;
var oldObj = {
name: "张三",
age: 18,
colors: ["skyblue", 'plum', "pink"],
status: {
hobby: "study",
}
}
2、定义递归函数deepClone(),实现深拷贝,方便调用;
function deepClone(obj) {
//判断传进来的参数类型不是对象数组 或者是null时 直接返回
if (typeof obj !== "object" || obj == null) {
return obj
}
//定义返回值
let result;
// 判断传进来的数据类型 是数组/对象 就给result一个数组/对象
if (obj instanceof Array) {
result = []
} else {
result = {}
}
//循环遍历方便拷贝
for (let key in obj) {
//判读自有属性
if (obj.hasOwnProperty(key)) {
//函数递归实现深层拷贝
result[key] = deepClone(obj[key])
}
}
//返回出去
return result
}
//优化
function deepClone(obj) {
//判断传进来的参数类型不是对象数组 或者是null时 直接返回
if (typeof obj !== "object" || obj == null) {
return obj
}
//定义返回值result
// 判断传进来的数据类型 是数组/对象 就给result一个数组/对象
let result = Array.isArray(obj) ? [] : {};
//循环遍历方便拷贝
for (let key in obj) {
//判读自有属性
if (obj.hasOwnProperty(key)) {
//函数递归实现深层拷贝
result[key] = deepClone(obj[key])
}
}
//返回出去
return result
}
** 2.1、obj instanceof Array 和 Array.isArray(obj)都是检测对象是否是一个数组的方法,更多判断数组的方法,详见**
3、调用函数,实现递归深拷贝;
const newObj = deepClone(oldObj);
//检验拷贝结果
newObj.name = "李四";
newObj.status.hobby = "敲代码";
newObj.colors[2] = "purple";
console.log("oldObj", oldObj);
console.log("newObj", newObj);
** 3.1、输出结果,未改变原有嵌套层级较深的数据,递归函数,深拷贝成功;**
4、具体使用,可以直接在项目中新建js文件导出该方法,然后引入使用,方便实现数据深拷贝:
1、导出:export function deepClone(obj) { ... }
2、引入:import { deepClone } from "../utils/clone.js";
3、使用:const data = deepClone(this.obj) console.log(data);
方便了很,哈哈,点赞收藏呀(●'◡'●)......
版权归原作者 北城笑笑 所有, 如有侵权,请联系我们删除。