对象引用
发布日期:2021-05-06 19:35:30 浏览次数:17 分类:技术文章

本文共 896 字,大约阅读时间需要 2 分钟。

1. 比较赋值和引用

赋值

这里写图片描述
引用(对象和函数都是引用的关系)
如下是因为a,b共用一个地址
这里写图片描述
如下b=[1,2,3,4],相当于给b新建了一个地址,a和b的地址不一样
这里写图片描述

2. 浅拷贝和深拷贝

拷贝一个对象如下

这里写图片描述
从上面可以看出来obj的a值也被改变了,为了避免这个问题(浅拷贝)

var obj={a:10};function copy(obj){
var newObj={}; for(var arr in obj){ newObj[attr]=obj[attr]; } return newObj;}var obj2=copy(obj);obj2.a=20;alert(obj.a);//10

浅拷贝存在的问题。从如下可以看出还是会影响前面的值。所以浅拷贝只是拷贝了一层。

var obj={a:{b:10}};function copy(obj){
var newObj={}; for(var arr in obj){ newObj[attr]=obj[attr]; } return newObj;}var obj2=copy(obj);obj2.a.b=20;alert(obj.a.b);//20

如下深拷贝,了解深拷贝之前了解一下递归

递归:1.函数调用函数自身,执行递的动作
2.最后一次判断一个终止条件,可以执行归的动作

function test(n){
if(n=1){ return 1; } return n*test(n-1);}alert(test(4))

回归上面的问题

var obj={a:{b:10}};function deepCopy(obj){
if(typeof obj!='object'){ return obj; } var newObj={}; for(var arr in obj){ newObj[attr]=deepCopy(obj[attr]); } return newObj;}var obj2=deepCopy(obj);obj2.a.b=20;alert(obj.a.b);//10
上一篇:JavaScript优化-DOM
下一篇:事件委托

发表评论

最新留言

感谢大佬
[***.8.128.20]2025年03月21日 04时27分13秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

Java.常用类.StringBuffer和StringBuilder 2019-03-04
RDD行动操作算子 --- fold(初始值)、reduce 2019-03-04
【Python数据分析与处理 实训02】 ---2012欧洲杯信息分析(数据过滤与排序) 2019-03-04
【Python数据分析与处理 实训04】--- 探索1960 - 2014美国犯罪数据(时间序列处理应用) 2019-03-04
KeyError: “[‘xxxx‘] not found in axis“ 2019-03-04
【Python数据分析与处理 实训05】--- 探索虚拟姓名数据(数据合并) 2019-03-04
java编程常见类型题 --- 面向对象编程、程序逻辑(金字塔)、多线程同步 2019-03-04
java编程常见类型题 --- 程序逻辑(最小台阶)、多线程(计算读取)、Swing布局(国际棋盘) 2019-03-04
【MapReduce】基础案例 ---- 自定义OutputFormat <根据内容输出到指定文件目录中> 2019-03-04
【Android】 模拟器上运行程序报错 2019-03-04
【sklearn练习】KMeans ---- iris(鸢尾花)数据集聚类评估 2019-03-04
【HTML5 CSS】display和visibility的区别 2019-03-04
java线程(4)——使用多个线程操作同一个对象(买票的例子) 2019-03-04
前端HTML中表单action属性的作用 2019-03-04
java线程(17)——Lock锁,三个线程抢票加上lock锁后变成三个线程排队买票 2019-03-04
java线程(19)——信号灯法,电视播放,生产者与消费者的案例 2019-03-04
java线程(20)——Runnable线程池 2019-03-04
计算机网络ip知识点 2019-03-04
react(3)——导入了正确的包,但是运行不出来,原因是因为导入包的顺序有问题 2019-03-04
react(10)——三大属性state,props,refs,总结其特点 2019-03-04