首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS完美收官之浅克隆和深克隆

1996年7月5日,在英国爱丁堡市罗斯林研究所出生了一只克隆羊多莉,克隆英文名"clone",clone起源于希腊文"klone",也称为无性繁殖,克隆是生物体通过体细胞进行无性繁殖,最终形成基因完全相同的后代...浅克隆 什么是浅克隆?浅克隆就是当我把obj{}对象里面的所有属性拷贝到obj1{}中后,然后我分别改变对象里面的变量,原始值互不影响,引用值一个改变,另一个跟着变。...: 从执行结果可以看出修改原始值时互不影响,一旦修改引用值时,一个改,另一个跟着变,这就是浅克隆。...深克隆(主要) 那什么是深克隆呢?深克隆就是修改引用值时,互不影响,你改我不变。...in obj)遍历对象 判断是不是原始值,原始值可以直接拷贝,引用值就要进一步处理,引用值又分数组和对象,所以在第二步中判断数组还是对象。

1.3K20

JS面试题】深克隆 和 浅克隆 有了解过吗?能手写深克隆吗?

克隆 和 浅克隆 有了解过吗?能手写深克隆吗? 什么是克隆克隆其实就是拷贝,就是把一个对象中的属性复制一份,放到另一个对象中的过程。而属性的数据是有原始值和引用值之分。...浅克隆:当我们复制对象中属性的时候,如果是原始值,则两个对象中的变量随意修改,两者互不影响(敌动我不动)。如果是引用值,一个对象的变量改变,则另一个对象跟着变(敌动我便动)。...深克隆:深克隆就是解决拷贝引用值时“敌动我便动”的问题,无论数据怎么修改,两者互不影响。...深克隆的实现有两种方式:递归拷贝和JSON函数拷贝,我会用这两种方式分别来实现深拷贝 递归拷贝:将obj克隆到newObj中 let obj = { name: "前端猎手",...[] : {}; //建立相对应的数组或对象 deepClone(origin[prop], target[prop]); //递归,为了拿到引用值里面还有引用

1.5K10

js如何引用同级元素

具体效果 示例效果 https://coder.itclan.cn/fontend/js/17-yinyong-tongji-elem/ 具体描述 在网页中,同级(兄弟)元素,指的是拥有相同的直接父级元素的元素...并且往往指的是同类的元素,同类元素在实际开发中遇到的比较多 比如:列表li,并列的按钮等,当需要做一些特殊的效果时,可以对其他同级的元素进行一些操作,满足特定的网页要求 比如:隔行填充颜色等 原生方法实现 以下是通过原生js...就是同级元素,同级元素拥有相同的父级元素都是p,那么就可以得到除自身以外的的同级元素,如果还需要排除同一类别的话,那么可以使用节点的nodeType属性来加以区别 Vue版本实现 在Vue里面,就不用类似原生js...margin: 20px 0; } .content { padding: 20px 0 0 0; } 从上面可以看出,使用Vue实现类似同样的效果,就几行代码,相比原生js...实现是比较简单的,但是原生js的操作依旧还是要知道的

7.8K40

克隆和浅克隆

概述 Java 集合中提供的拷贝构造函数只支持浅拷贝而不是深拷贝,这是因为集合中的拷贝构造函数是通过引用的复制来达到浅拷贝的。这意味着存储在原有集合和克隆集合中的对象会保持一致(指向同一内存地址)。...浅拷贝 定义 浅拷贝其实是把一个对象的值复制一份到克隆的对象中。不需要去执行构造函数,所以效率会快很多,这是浅拷贝的一个优点。...但是对于可变类来说,克隆以后对象的值并没有和原对象分离开来,而是相互影响,所以这是浅拷贝的一个缺点。 ?...这样的话,克隆后的对象的值和原来的对象的值互不影响。因为他们指向的是堆内存中不同的内存空间。 ? 实现方案 重写 Object 的 clone 方法,并将每个可变类属性也克隆一次。...浅克隆拷贝的值(对象的话就是引用值),使用的同一块内存空间。深拷贝拷贝值的同时还创建了内存空间,使用的是不同的内存空间。不可变类对象的拷贝使用浅克隆就行。

2.1K10

Java | 浅克隆与深克隆

克隆与深克隆的区别 浅克隆:复制对象时仅仅复制对象本身,包括基本属性,但该对象的属性引用其他对象时,该引用对象不会被复制,即拷贝出来的对象与被拷贝出来的对象中的属性引用的对象是同一个。...深克隆:复制对象本身的同时,也复制对象包含的引用指向的对象,即修改被克隆对象的任何属性都不会影响到克隆出来的对象。 ? ?...但当被克隆的对象的属性引用其他对象时,此时会有不同的结果。...,并不会克隆对象的属性引用的对象,当修改被克隆对象的成绩时,克隆出来的对象也会跟着改变,即两个对象的属性引用指向的是同一个对象。...值得一提的是,上文所说的浅拷贝只会克隆基本数据属性,而不会克隆引用其他对象的属性,但 String 对象又不属于基本属性,这又是为什么呢?

1.6K20

浅谈深克隆和浅克隆

克隆:创建一个新对象,新对象的属性和原来对象完全相同,对于非基本类型属性,仍指向原有属性所指向的对象的内存地址。 深克隆:创建一个新对象,属性中引用的其他对象也会被克隆,不再指向原有对象地址。...如图所示,深克隆和浅克隆之后对象的指向地址差异。 pos:当前对象的地址; son:son属性所指向的地址; name:对象的name属性。...1055780-20190821154716863-900289879.jpg 浅克隆实现: 对象实现Cloneable并重写clone方法不进行任何操作时,调用clone()方法将实现浅克隆。...便捷方式使用HuTool,继承cn.hutool.clone.CloneSupport类或者实现cn.hutool.clone.Cloneable接口 深克隆实现: 将对象流将对象写入流然后再读出。

2K00

原生JS | 值类型与引用类型变量

HTML5学堂-码匠:在JavaScript中,存在着两种不同的变量类型,一种是值类型变量,一种是引用类型变量。...其中数组、对象、函数都属于引用类型变量,数值、布尔值、null、undefined、字符串属于值类型变量,不同类型变量在参数传递方面有不同的运行机制。...控制台的打印结果为: HTML5学堂 码匠 实例2运行后,控制台的打印结果为: 码匠 码匠 两种实例不同结果的“根源” 导致这两种不同结果的根源在于JavaScript中的变量类型分为两大类:值类型和引用类型...引用类型变量 引用类型包括:对象、数组、函数。 引用类型变量的交换,并不会创建一个新的空间,而是让新变量和之前的变量,同时指向一个原有空间(即同一个地址)。可以理解为C语言的指针。

3.4K90

简单理解浅克隆和深克隆

定义 浅克隆(Shadow Clone): 拷贝对象时仅仅拷贝对象本身,而不拷贝对象包含的引用指向的对象;对于数据类型是基本数据类型的成员变量,会直接进行值传递,也就是将该属性值复制一份给新的对象。...深克隆(Deep Clone): 将原型对象中所有类型,无论是值类型还是引用类型,都复制一份给克隆对象。...所以这里引入了深克隆。即要克隆类的基本数据类型,以及所有非基本数据类型的属性。...这里简单的示例帮助理解深克隆和浅克隆。...深克隆方式 1、实现Cloneable接口 2、使用JDK自带的字节流实现深克隆 3、使用第三方工具类实现深克隆,比如Apache Commons Lang 4、使用Json工具实现深克隆,比如Gson

8610
领券