javascript 对象属性赋值 变量赋值

发布于 2022-09-02 14:50:44 字数 264 浏览 29 评论 0

var obj1 = {
    a : {
        a1 :{ t:'123'},
        a2 :'456'
    },
    b : 'b'
}
var tmp0 = obj1;
var tmp1 = obj1.a;

//此时做一下操作
obj1.a = {};
console.log(tmp0,tmp1);
问题:tmp0修改了 因为他和obj1指向同一个对象,这个理解;tmp1为何没有变,不应该也指向空对象吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

π浅易 2022-09-09 14:50:44

前面不说了,就说最后两步

var temp1 = obj1.a

相当于图片描述

obj1.a = {}

相当于图片描述

tmp1当然结果没变了

给你贴个神器,一般人我不告诉他,哈哈

各空 2022-09-09 14:50:44

tmp1存的是一个地址指向{a1 :{ t:'123'}, a2 :'456'}这个对象。obj1.a一开始也是存了相同的地址。当obj1.a={}的时候,a的值变为指向这个空对象的地址,但是,tmp1并没有变。

冷情 2022-09-09 14:50:44

对象引用,值拷贝

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文