广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >javascript如何实现深克隆
  • 147
分享到

javascript如何实现深克隆

2024-04-02 19:04:59 147人浏览 安东尼
摘要

小编给大家分享一下javascript如何实现深克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

小编给大家分享一下javascript如何实现深克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

javascript实现深克隆的方法:1、利用“…”延展操作符,可以深克隆一层,但是第二层引用仍然指向原来的位置;2、利用JSON,可以实现多层的深克隆,但是无法复制function,无法适用全部场景;3、利用递归和循环挨个创建参数和赋值。

教程操作环境:windows10系统、javascript1.8.5版、Dell G3电脑。

javascript怎么实现深克隆

由于Object类型与Array类型是引用类型,而引用类型在变量间的相互赋值是将指向内存的指针赋予过去,这样就会导致,当改变b的数据会将a的数据一同改变。

javascript如何实现深克隆
而在实际的开发过程中,有很多时候需要将两个变量间的关联断开,所以需要用到深克隆断开这个联系。

1、使用延展操作符(…)实现深克隆

这种方式是最简单且便捷的一种方式,但是只能深克隆一层,第二层的引用依然指向原来的位置。

javascript如何实现深克隆

2、使用jsON实现深克隆

这种方式也比较简便,并且可以实现多层的深克隆,但是无法复制function,无法适用全部场景。

javascript如何实现深克隆
3、使用递归和循环挨个创建参数和赋值

能够完全复制一个对象

// 深克隆function deepCopy(value) {
	if(value instanceof Function)return value    else if (value instanceof Array) {
        var newValue = []
        for (let i = 0; i < value.length; ++i) newValue[i] = deepCopy(value[i])
        return newValue    } else if (value instanceof Object) {
        var newValue = {}
        for (let i in value) newValue[i] = deepCopy(value[i])
        return newValue    } else return value}

javascript如何实现深克隆

以上是“javascript如何实现深克隆”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网VUE频道!

--结束END--

本文标题: javascript如何实现深克隆

本文链接: https://www.lsjlt.com/news/92871.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • javascript如何实现深克隆
    小编给大家分享一下javascript如何实现深克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2022-10-19
  • JavaScript如何实现多级对象的深度克隆
    这篇文章给大家分享的是有关JavaScript如何实现多级对象的深度克隆的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。多级对象的深度克隆要深度克隆多级对象,可以遍历每个属性,并检查当前属性是否包含对象。如果是,则...
    99+
    2023-06-27
  • php中如何实现克隆
    小编给大家分享一下php中如何实现克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!定义:克隆对象clone,即通过已有的对象复制一个新的同样的对象,但是两者之间...
    99+
    2023-06-14
  • OpenCV如何实现无缝克隆算法
    这篇“OpenCV如何实现无缝克隆算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“OpenCV如何实现无缝克隆算法”文章吧...
    99+
    2023-07-02
  • Python怎么实现克隆图
    本篇内容介绍了“Python怎么实现克隆图”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!题目:给定无向连通图中一个节点的引用,返回该图的深拷...
    99+
    2023-06-02
  • 如何实现centos复制克隆改网卡
    这篇文章主要讲解了“如何实现centos复制克隆改网卡”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现centos复制克隆改网卡”吧!备份etc/udev/rules.d/70-per...
    99+
    2023-06-10
  • java克隆模式怎么实现
    在Java中,克隆模式可以通过实现Cloneable接口和重写Object类的clone()方法来实现。下面是一个简单的例子:首先,...
    99+
    2023-08-30
    java
  • Java对象克隆怎么实现
    本篇内容主要讲解“Java对象克隆怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java对象克隆怎么实现”吧! Overiew在实际编程中,我们经常会遇到这样一个情景:有一个对象A,存在...
    99+
    2023-06-17
  • java怎么实现对象克隆
    在Java中,可以通过两种方式来实现对象克隆:浅拷贝和深拷贝。1. 浅拷贝:使用Object类的clone()方法进行对象的浅拷贝。...
    99+
    2023-08-18
    java
  • DOM节点深度克隆函数cloneNode()用法实例
    DOM节点深度克隆函数cloneNode()用于创建调用该方法的节点的一个副本,并返回该副本。以下是一个示例,其中实例化了一个元素,...
    99+
    2023-08-17
    DOM
  • 如何克隆github项目
    近年来,Github已经成为开源界的标准选择,你可以在上面找到数千个优秀的项目,学习和使用这些项目并不困难,你可以通过克隆(clone)来将这些项目复制到你的计算机上。但是,一些新手可能会在这个过程中遇到一些问题。因此本文将给你介绍如何克隆...
    99+
    2023-10-22
  • github如何克隆分支
    GitHub作为目前全球最大的代码托管平台,为开发者们提供了非常便捷的协作开发体验。在实际开发中,我们常常需要从GitHub上克隆代码到本地进行开发和调试。这时,如何克隆指定的分支就是一个需要掌握的技能。GitHub上的每一个仓库都可以包含...
    99+
    2023-10-22
  • jQuery如何克隆对象
    小编给大家分享一下jQuery如何克隆对象,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!克隆对象$(document).read...
    99+
    2022-10-19
  • Javascript深度克隆中的循环引用问题怎么解决
    这篇文章主要介绍“Javascript深度克隆中的循环引用问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Javascript深度克隆中的循环引用问题怎么...
    99+
    2022-10-19
  • VB.NET中怎么实现对象克隆
    VB.NET中怎么实现对象克隆,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在3DMAX里面,做好一个物体(父物体)以后,可以选择Edit菜单中的Clone,下面有三中选项...
    99+
    2023-06-17
  • C++实现LeetCode(133.克隆无向图)
    [LeetCode] 133. Clone Graph 克隆无向图 Given a reference of a node in a connected ...
    99+
    2022-11-12
  • JavaScript数组及非数组对象的深浅克隆详解原理
    目录什么是浅克隆、深克隆1.对数组进行克隆1.1 浅克隆1.2 深克隆2.对非数组对象进行克隆2.1 浅克隆2.2 深克隆3.整合深克隆函数什么是浅克隆、深克隆 浅克隆:直接将存储在...
    99+
    2022-11-12
  • 如何使用rman克隆Oracle
    这篇文章主要介绍如何使用rman克隆Oracle,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!RMAN(Recovery Manager)是随Oracle服务器软件一同安装的工具软件,它可以用来备份和恢复数据库文件、...
    99+
    2023-06-27
  • unity如何获取克隆物体
    要在Unity中获取克隆的物体,你可以使用Instantiate函数。该函数接受一个原始物体作为参数,并返回该物体的克隆。 下面是一...
    99+
    2023-10-27
    unity
  • 如何备份克隆数据库
    这篇文章主要介绍如何备份克隆数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! ---基于备份克隆1、创建pfile  create pfi...
    99+
    2022-10-19
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作