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

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

1996年7月5日,在英国爱丁堡市罗斯林研究所出生了一只克隆羊多莉,克隆英文名"clone",clone起源于希腊文"klone",也称为无性繁殖,克隆是生物体通过体细胞进行无性繁殖,最终形成基因完全相同的后代...,多莉与多塞特母绵羊具有完全相同的外貌,而我们程序中的克隆跟这类似,就是把一个对象中的属性复制一份放到另一个对象中。...浅克隆 什么是浅克隆?浅克隆就是当我把obj{}对象里面的所有属性拷贝到obj1{}中后,然后我分别改变对象里面的变量,原始值互不影响,引用值一个改变,另一个跟着变。...return target; } clone(obj, obj1); 当引用值修改时: 从执行结果可以看出修改原始值时互不影响,一旦修改引用值时,一个改,另一个跟着变,这就是浅克隆...深克隆(主要) 那什么是深克隆呢?深克隆就是修改引用值时,互不影响,你改我不变。

1.3K20

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

克隆 和 浅克隆 有了解过吗?能手写深克隆吗? 什么是克隆克隆其实就是拷贝,就是把一个对象中的属性复制一份,放到另一个对象中的过程。而属性的数据是有原始值和引用值之分。...深克隆:深克隆就是解决拷贝引用值时“敌动我便动”的问题,无论数据怎么修改,两者互不影响。...深克隆的实现有两种方式:递归拷贝和JSON函数拷贝,我会用这两种方式分别来实现深拷贝 递归拷贝:将obj克隆到newObj中 let obj = { name: "前端猎手",...} } } return target; } deepClone(obj,newObj) 代码验证: JSON...(JSON.stringify(obj)); obj.idol.achievement[0] = "green apple"; newObj.idol.achievement

1.5K10

jsJSON详解

理解 JSON 最关键的一点是要把它当成一种数据格式,而不是编程语言。JSON不属于JavaScript,它们只是拥有相同的语法而已。...JSON 也不是只能在 JavaScript 中使用,它是一种通用数据格式。很多语言都有解析和序列化JSON的内置能力。 1....1.1 简单值 最简单的 JSON 可以是一个数值。例如,下面这个数值是有效的 JSON: 1 类似地,下面这个字符串也是有效的 JSON: “Hello World!”...2.1 JSON对象 JSON对象有两个方法: stringify():将js序列化为JSON字符串; parse():将JSON解析为js值。...如果给 JSON.parse()传入的 JSON 字符串无效,则会导致抛出错误。 2.2 序列化选项 JSON.stringify()方法除了要序列化的对象,还可以接收两个参数。

7.5K20

克隆和浅克隆

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

2.1K10

js数组、jsonjs对象的区别与联系

最近在敲代码时,遇上了一个关于JS数组的问题,由此引发了关于对象和json的联想,曾经觉得很畅顺的知识点突然模糊了。于是,为了理清这些东西,有了如下这篇文章。...person.key=“value” ; (3)json:一种存储和交换信息的格式,常态为var json = {“key”:“value”}的格式,这里和js对象不同的是key多了“” 区别与联系:...字符串) ==》 转化成json对象 JSON.stringify(json对象) ==》转化为json字符串 二、js对象与json对象 js对象, var person = {key:“...记得上面概念里,js所有事物都是对象,那么我们完全可以把json对象当做js对象的子集,string只是js对象的key的数据类型中的一个选项 额外说一点,js里面是没有键值对数组这一说的,现有的这种键值对数组...,即map json格式常用于数据传输方面,其他情况遇到类似json对象的形式,可以把它当成是特殊的js对象来处理,例子如下 var a = { “star”:{“img”:require

9.2K40
领券