问题: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);

为什么会出现这样的结果呢?

因为这里返回一个已经定义好的对象,每次返回的都是同一个内存地址,所以只要其中提个对象属性被改变,通过该方法返回对象的属性都会改变

 

最新文章

  1. 转-深入理解VMware虚拟网络
  2. ItextDemo<二>
  3. JS中检测数据类型的四种方法
  4. 【BZOJ 3545】【ONTAK 2010】Peaks & 【BZOJ 3551】【ONTAK 2010】Peaks加强版 Kruskal重构树
  5. Python join()方法
  6. Insertion Sort List —— LeetCode
  7. ubuntu12 环境下编译freerdp
  8. CSS3+HTML5特效4 - 横向无缝滚动
  9. loadrunner动态从mysql取值
  10. java实现Windows记事本
  11. 13、vue.js简单入门
  12. [LeetCode] Sliding Puzzle 滑动拼图
  13. SPFA找最大比例环
  14. <工厂方法>比<简单工厂>多了啥
  15. python 0228
  16. ElasticSearch入门简介
  17. selenium自动化之鼠标操作
  18. 1. 配置win7下odbc数据源找不到数据库驱动的问题
  19. maven使用阿里镜像配置文件
  20. ubuntu下安装程序的五种方法

热门文章

  1. 简易数据分析 12 | Web Scraper 翻页——抓取分页器翻页的网页
  2. Java中关于泛型集合类存储的总结
  3. [SpringBoot——Web开发(使用Thymeleaf模板引擎)]
  4. 控制执行流程之ForEach语法
  5. 使用CoordinatorLayout打造各种炫酷的效果
  6. JavaScript之数据类型转换
  7. java+selenium-3.9.1多线程 打开连接截取屏幕截图
  8. 使用gdb调试c++程序
  9. 【linux】【jenkins】自动化运维七 整合sonarqube代码审查
  10. 判断dom原始是否在可视区域内