我的编程空间,编程开发者的网络收藏夹
学习永远不晚

javascript如何实现深克隆

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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如何实现深克隆”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

javascript如何实现深克隆

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

下载Word文档

猜你喜欢

JavaScript如何实现多级对象的深度克隆

这篇文章给大家分享的是有关JavaScript如何实现多级对象的深度克隆的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。多级对象的深度克隆要深度克隆多级对象,可以遍历每个属性,并检查当前属性是否包含对象。如果是,则
2023-06-27

php中如何实现克隆

小编给大家分享一下php中如何实现克隆,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!定义:克隆对象clone,即通过已有的对象复制一个新的同样的对象,但是两者之间
2023-06-14

OpenCV如何实现无缝克隆算法

这篇“OpenCV如何实现无缝克隆算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“OpenCV如何实现无缝克隆算法”文章吧
2023-07-02

如何实现centos复制克隆改网卡

这篇文章主要讲解了“如何实现centos复制克隆改网卡”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现centos复制克隆改网卡”吧!1.备份etc/udev/rules.d/70-p
2023-06-10

Python怎么实现克隆图

本篇内容介绍了“Python怎么实现克隆图”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!题目:给定无向连通图中一个节点的引用,返回该图的深拷
2023-06-02

jQuery如何克隆元素?

jQuery克隆元素jQuery提供多种方法来克隆元素,包括浅层克隆(包含子节点和属性)、深层克隆(包含事件处理程序)和完整克隆(包括所有内容)。方法:clone():浅层克隆clone(true):深层克隆cloneNode():完整克隆用途:创建可重用内容块创建交互式小部件管理表单输入创建动画效果最佳实践:根据需要选择克隆类型如果需要事件处理程序,请使用深层克隆在使用前检查元素是否存在
jQuery如何克隆元素?
2024-04-08

如何克隆虚拟机

要克隆一个虚拟机,通常需要使用虚拟化软件提供的克隆功能。以下是在常见的虚拟化软件中克隆虚拟机的步骤:VMware vSphere/ESXi:在vSphere/ESXi中,可以使用vCenter Server或者ESXi主机来克隆虚拟机。在v
如何克隆虚拟机
2024-06-11

github如何克隆分支

GitHub作为目前全球最大的代码托管平台,为开发者们提供了非常便捷的协作开发体验。在实际开发中,我们常常需要从GitHub上克隆代码到本地进行开发和调试。这时,如何克隆指定的分支就是一个需要掌握的技能。GitHub上的每一个仓库都可以包含
2023-10-22

java怎么实现对象克隆

在Java中,可以通过两种方式来实现对象克隆:浅拷贝和深拷贝。1. 浅拷贝:使用Object类的clone()方法进行对象的浅拷贝。浅拷贝会创建一个新的对象,将原始对象的非静态字段的值复制到新对象中,对于引用类型的字段,复制的是引用而不是对
2023-08-18

如何克隆github项目

近年来,Github已经成为开源界的标准选择,你可以在上面找到数千个优秀的项目,学习和使用这些项目并不困难,你可以通过克隆(clone)来将这些项目复制到你的计算机上。但是,一些新手可能会在这个过程中遇到一些问题。因此本文将给你介绍如何克隆
2023-10-22

Java对象克隆怎么实现

本篇内容主要讲解“Java对象克隆怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java对象克隆怎么实现”吧!1. Overiew在实际编程中,我们经常会遇到这样一个情景:有一个对象A,
2023-06-17

java克隆模式怎么实现

在Java中,克隆模式可以通过实现Cloneable接口和重写Object类的clone()方法来实现。下面是一个简单的例子:首先,创建一个可克隆的原型类:```javapublic class Prototype implements C
2023-08-30

如何使用rman克隆Oracle

这篇文章主要介绍如何使用rman克隆Oracle,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!RMAN(Recovery Manager)是随Oracle服务器软件一同安装的工具软件,它可以用来备份和恢复数据库文件、
2023-06-27

DOM节点深度克隆函数cloneNode()用法实例

DOM节点深度克隆函数cloneNode()用于创建调用该方法的节点的一个副本,并返回该副本。以下是一个示例,其中实例化了一个元素,并使用cloneNode()方法创建了该元素的副本。然后,将副本插入到文档中的另一个位置。```htmlHe
2023-08-17

VB.NET中怎么实现对象克隆

VB.NET中怎么实现对象克隆,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在3DMAX里面,做好一个物体(父物体)以后,可以选择Edit菜单中的Clone,下面有三中选项
2023-06-17

编程热搜

目录