js通过方法返回对象的注意点

摘要:s通过方法返回一个字面量对象和返回一个提前已经定义好的字面量对象有区别吗?我们先来看看第一种情况,fun1方法返回一个提前没定义的字面量对象,然后通过调用方法返回三个对象

问题: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属性

//第二种情况:
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);
结果:
obj21.age = 18 
obj21.age = 16 
obj21.age = 18

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

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


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_6001