引用JS对象中的内部变量[重复]

问题描述 投票:0回答:1

这个问题在这里已有答案:

在这样一个简单的JS对象中:

var LeadserData = {
    agent_id: 2,

    object_queries: {
        emails: {
            url: "/manual_emails/",
            method: 'GET',
              send_data: { 
                   the_id: this.agent_id
              }
        }
    }
}

显然可以像这样访问agent_id:

LeadserData.agent_id = 100;
alert(LeadserData.agent_id);

这显然会返回100.但为什么this.agent_id的内部参考不起作用?

alert((LeadserData.object_queries.emails.send_data.the_id));

我原本期望它也会出现“100”,但相反它是未定义的。整个小提琴在这里:https://jsfiddle.net/h88zc5nw/1/

这种行为的解释是什么,我如何调整它以返回预期的100

javascript singleton
1个回答
1
投票

首先,您使用的是对象文字。你不能在对象文字中使用this,至少它不会是你想象的那样。它将是构造对象文字时可用的任何this

其次,即使我们假设上述工作,数字是本机类型,它们也不会通过它们的引用共享。所以改变LeadserData.agent_id不会影响LeadserData.object_queries.emails.send_data.the_id,即使你已经分配给另一个。本机类型在赋值时被复制,而不是使用引用传递(就像您对对象一样)。

© www.soinside.com 2019 - 2024. All rights reserved.