JS 深克隆和浅克隆 浅析

这篇具有很好参考价值的文章主要介绍了JS 深克隆和浅克隆 浅析。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

        深克隆(Deep Clone)和浅克隆(Shallow Clone)是在复制对象或数组时常用的两种概念。它们主要区别在于复制的深

深克隆(Deep Clone):

        深克隆是指完全复制一个对象或数组,包括对象或数组中的所有嵌套对象或数组。在深克隆中,复制的结果是一个全新的对象或数组,与原始对象或数组完全独立,修改复制后的对象或数组不会影响原始对象或数组。深克隆会递归复制所有嵌套的对象或数组,确保每个对象或数组都是独立的。

浅克隆(Shallow Clone):

        浅克隆是指复制一个对象或数组,但只复制对象或数组的第一层结构,而不会复制嵌套的对象或数组。在浅克隆中,复制的结果仅包含原始对象或数组的引用,而不是深层的复制。因此,修改复制后的对象或数组的第一层结构可能会影响原始对象或数组。

        总结起来,深克隆会复制对象或数组的所有层级,确保每个对象或数组都是独立的,而浅克隆只会复制第一层结构,复制的结果包含原始对象或数组的引用。文章来源地址https://www.toymoban.com/news/detail-835641.html

深克隆方法:

  • 利用JSON序列化和反序列化
const originalArray = [1, 2, [3, 4]];
const deepCloneArray = JSON.parse(JSON.stringify(originalArray));

originalArray[2][0] = 300; // 修改原数组的第三个元素中的第一个元素

console.log(originalArray); // [1, 2, [300, 4]]
console.log(deepCloneArray); // [1, 2, [3, 4]],不受原数组修改的影响

  • 使用递归
function deepCloneArray(arr) {
    let clone = [];
    arr.forEach(item => {
        if (Array.isArray(item)) {
            clone.push(deepCloneArray(item));
        } else {
            clone.push(item);
        }
    });
    return clone;
}

const originalArray = [1, 2, [3, 4]];
const deepCloneArray = deepCloneArray(originalArray);

originalArray[2][0] = 300; // 修改原数组的第三个元素中的第一个元素

console.log(originalArray); // [1, 2, [300, 4]]
console.log(deepCloneArray); // [1, 2, [3, 4]],不受原数组修改的影响
  • 使用Lodash库
const _ = require('lodash');
const deepClone = (arr) => {
  return _.cloneDeep(arr);
}
  • 使用Map函数
function deepCloneArray(array) {
    return array.map(item => {
        if (Array.isArray(item)) {
            return deepCloneArray(item); // 递归调用深克隆函数
        } else if (typeof item === 'object' && item !== null) {
            return deepCloneObject(item); // 递归调用深克隆函数
        } else {
            return item; // 基本数据类型直接返回
        }
    });
}

function deepCloneObject(obj) {
    let clonedObj = {};
    for (let key in obj) {
        if (Array.isArray(obj[key])) {
            clonedObj[key] = deepCloneArray(obj[key]); // 对数组进行深克隆
        } else if (typeof obj[key] === 'object' && obj[key] !== null) {
            clonedObj[key] = deepCloneObject(obj[key]); // 对对象进行深克隆
        } else {
            clonedObj[key] = obj[key]; // 基本数据类型直接复制
        }
    }
    return clonedObj;
}

// 示例
const originalArray = [1, 2, [3, 4], {a: 5, b: [6, 7]}];
const clonedArray = deepCloneArray(originalArray);

console.log(originalArray); // 原始数组
console.log(clonedArray); // 深克隆后的数组

浅克隆方法:

  • 直接赋值
  • 使用slice()方法
const originalArray = [1, 2, [3, 4]];
const shallowCloneArray = originalArray.slice();

originalArray[2][0] = 300; // 修改原数组的第三个元素中的第一个元素

console.log(originalArray); // [1, 2, [300, 4]]
console.log(shallowCloneArray); // [1, 2, [300, 4]],受原数组修改的影响
  • 使用concat()方法
const originalArray = [1, 2, [3, 4]];
const shallowCloneArray = originalArray.concat();

originalArray[2][0] = 300; // 修改原数组的第三个元素中的第一个元素

console.log(originalArray); // [1, 2, [300, 4]]
console.log(shallowCloneArray); // [1, 2, [300, 4]],受原数组修改的影响
  • 使用扩展操作符
const shallowClone = (arr) => {
  return [...arr];
}
  • 使用Array.from方法
const shallowClone = (arr) => {
  return Array.from(arr);
}
  • 使用Object.assign()方法
const shallowClone = (arr) => {
  return Object.assign([], arr);
}

到了这里,关于JS 深克隆和浅克隆 浅析的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【前端知识】JavaScript——Symbol类型

    什么是Symbol(符号)类型? ​ Symbol是原始值,且Symbol实例是唯一、不可变的。Symbol的用途是确保对象属性使用唯一标识符,不会发生属性冲突的危险。Symbol创建唯一记号,进而用作非字符串形式的对象属性。 如何使用Symbol? 全局符号注册表 使用符号作为属性 常用内置符号

    2024年02月16日
    浏览(42)
  • 学习Node.js需要哪些JavaScript知识

    Lexical Structure ( 词法 ) JavaScript 的词法(lexical grammar)。ECMAScript 源码文本会被从左到右扫描 ,并被转换为一系列的输入元素,包括 token、控制符、行终止符、注释和空白符。ECMAScript 定义了一些、字面量以及行尾分号补全的规则。 Expressions ( 表达式 ) JavaScript 中的

    2024年02月03日
    浏览(42)
  • 学习javascript,前端知识精讲,助力你轻松掌握

    ✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 所属专栏: 前端泛海 景天的主页: 景天科技苑 JavaScript在1995年诞生了; 由Netscape公司,布兰登·艾奇(Brendan Eich)发明的ECMAScript客户端脚本语言; 主要应用在浏览器,在当时却不温不火. 直到后来Netscape与S

    2024年03月15日
    浏览(62)
  • jQuery.js - 前端必备的Javascript库

    作者: WangMin 格言: 努力做好自己喜欢的每一件事 jQuery.js 是什么? jQuery是一个快速简洁、免费开源易用的JavaScript框架, 倡导写更少的代码,做更多的事情 。它封装JavaScript常用的功能代码,提供了一种简便的JavaScript设计模式,以及我们开发中常用到的操作DOM的API,优化HTML文

    2024年02月05日
    浏览(70)
  • 【前端知识】JavaScript——var 与 let 的区别

    var声明的变量会自动提升到函数作用域顶部,而let不会。 在解析代码时,JavaScript 引擎会注意出现在块后面的 let 声明,只不过在此之前不能以任何方式来引用未声明的变量。在 let 声明之前的执行瞬间被称为 暂时性死区(temporal dead zone) ,在此阶段引用任何后面才声明的变

    2024年02月16日
    浏览(43)
  • web前端框架JS学习之JavaScript类型转换

    vascript有多种数据类型,如字符串、数字、布尔等,可以通过typeof语句来查看变量的数据类型。数据类型转换就是数据类型之间相互转换,比如把数字转成字符串、把布尔值转成字符串、把字符串转成数字等,这在工作也是经常碰到的。 本期我们就给大家说说web前端框架JS学

    2024年02月10日
    浏览(59)
  • 【JS笔记】JavaScript语法 《基础+重点》 知识内容,快速上手(四)

    BOM(Browser Object Model): 浏览器对象模型 其实就是操作浏览器的一些能力 我们可以操作哪些内容 获取一些浏览器的相关信息(窗口的大小) 操作浏览器进行页面跳转 获取当前浏览器地址栏的信息 操作浏览器的滚动条 浏览器的信息(浏览器的版本) 让浏览器出现一个弹出

    2024年01月18日
    浏览(49)
  • 【前端灵魂脚本语言JavaScript⑤】——JS中数组的使用

    🐚 作者: 阿伟 💂 个人主页: Flyme awei 🐋 希望大家多多支持😘一起进步呀! 💬 文章对你有帮助👉关注✨点赞👍收藏📂 第一种: var 数组名 = new Array(); 创建一个空数组 第二种: var arr2 = new Array(10); 创建一个定长为10的数组 第三种 var arr3 = new Array(a,b,c); 创建时直接指定元素值

    2023年04月08日
    浏览(59)
  • 【前端知识】JavaScript——设计模式(工厂模式、构造函数模式、原型模式)

    工厂模式是一种众所周知的设计模式,广泛应用于软件工程领域,用于抽象创建特定对象的过程。 优点:可以解决创建多个类似对象的问题 缺点:没有解决对象标识问题(即新创建的对象是什么类型) 示例: 构造函数模式与工厂模式相比,没有显式地创建对象,其属性和方

    2024年02月15日
    浏览(45)
  • 〖大前端 - 基础入门三大核心之JS篇㉓〗- JavaScript 的「数组」

    当前子专栏 基础入门三大核心篇 是免费开放阶段 。 推荐他人订阅,可获取扣除平台费用后的35%收益,文末名片加V! 说明:该文属于 大前端全栈架构白宝书专栏, 目前阶段免费开放 , 购买任意白宝书体系化专栏可加入 TFS-CLUB 私域社区。 福利:除了通过订阅\\\"白宝书系列专

    2024年02月04日
    浏览(67)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包