js通过方法返回对象的注意点
2024-09-01 00:47:57
问题:js通过方法返回一个字面量对象和返回一个提前已经定义好的字面量对象有区别吗?
答案:有
我们先来看看第一种情况,fun1方法返回一个提前没定义的字面量对象,然后通过调用方法返回三个对象,分别是obj1, obj2, obj3,然后我修改obj2对象的age方法,打印obj1, obj2, obj3,的age属性分别是什么?
//第一种情况:
function fun1() { return {
uname: `ash`,
age: 18
}
//这里返回一个字面量对象,
//每次返回的不是同一对象地址,所以改变obj2的age属性,obj1,obj3,age属性是不会有影响的
}
obj1 = fun1();
obj2 = fun1();
obj3 = fun1();
obj2.age = 16;
console.log(obj1.age);
console.log(obj2.age);
console.log(obj3.age);
打印结果 :
obj1.age = 18
obj2.age = 16
obj3.age = 18
为什么户出现这样的结果呢?因为fun1每次返回的不是同一对象地址,所以改变obj2的age属性,obj1,obj3,age属性是不会有影响
再看第二种情况,我先定义好obj3,通过fun2()方法返回这个对象,现在我调用fun2方法,返回obj21 obj22 obj23 对象,修改obj22对象的age属性为16,分别打印obj21 obj22 obj23 对象的age属性
结果:
obj21.age = 18
obj21.age = 16
obj21.age = 18
//第二种情况:
var obj3 = {
uname: `ash`,
age: 18
}; function fun2() {
return obj2;
}
obj21 = fun2();
obj22 = fun2();
obj23 = fun2();
obj2.age = 16;
console.log(obj21.age);
console.log(obj22.age);
console.log(obj23.age);
为什么会出现这样的结果呢?
因为这里返回一个已经定义好的对象,每次返回的都是同一个内存地址,所以只要其中提个对象属性被改变,通过该方法返回对象的属性都会改变
最新文章
- 转-深入理解VMware虚拟网络
- ItextDemo<;二>;
- JS中检测数据类型的四种方法
- 【BZOJ 3545】【ONTAK 2010】Peaks &; 【BZOJ 3551】【ONTAK 2010】Peaks加强版 Kruskal重构树
- Python join()方法
- Insertion Sort List —— LeetCode
- ubuntu12 环境下编译freerdp
- CSS3+HTML5特效4 - 横向无缝滚动
- loadrunner动态从mysql取值
- java实现Windows记事本
- 13、vue.js简单入门
- [LeetCode] Sliding Puzzle 滑动拼图
- SPFA找最大比例环
- <;工厂方法>;比<;简单工厂>;多了啥
- python 0228
- ElasticSearch入门简介
- selenium自动化之鼠标操作
- 1. 配置win7下odbc数据源找不到数据库驱动的问题
- maven使用阿里镜像配置文件
- ubuntu下安装程序的五种方法
热门文章
- 简易数据分析 12 | Web Scraper 翻页——抓取分页器翻页的网页
- Java中关于泛型集合类存储的总结
- [SpringBoot——Web开发(使用Thymeleaf模板引擎)]
- 控制执行流程之ForEach语法
- 使用CoordinatorLayout打造各种炫酷的效果
- JavaScript之数据类型转换
- java+selenium-3.9.1多线程 打开连接截取屏幕截图
- 使用gdb调试c++程序
- 【linux】【jenkins】自动化运维七 整合sonarqube代码审查
- 判断dom原始是否在可视区域内