首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在javascript中将变量赋给对象内的另一个变量

如何在javascript中将变量赋给对象内的另一个变量
EN

Stack Overflow用户
提问于 2018-02-21 19:27:25
回答 5查看 72关注 0票数 0
代码语言:javascript
运行
复制
myObj={
a: 10,
b: this.a
}
console.log('b :',myObj.b)

这给出了b的值作为undefined。这样做的正确方法是什么?

EN

回答 5

Stack Overflow用户

发布于 2018-02-21 19:29:18

您可以使用简单的方法在同一对象的新属性中获取该值,因为JavaScript的工作方式与您预期的不同。

代码语言:javascript
运行
复制
var myObj={
   a: 10
};
myObj.b = myObj.a;
console.log('b :',myObj.b)

票数 3
EN

Stack Overflow用户

发布于 2018-02-21 19:31:24

您的this当前是全局对象,即undefined。您可以创建一个函数(闭包)来确保您的this是您想要的。或者,您可以在该对象外部创建一个全局var,并将该对象的一个属性分配给它。

不过,我不知道你到底想做什么。

如果你想要一个例子,你可以这样做,例如:

代码语言:javascript
运行
复制
function Person() {
   this.a = 10;
   this.b = this.a; // is this what you want? (why?)
}

然后,您可以输入var x = new Person()创建一个Person

不管怎样,这里发生的事情是,我创建了一个javascript闭包(也称为函数),它有它的this属性。否则this将是undefined (除非您在浏览器上,否则它将是window,或者,如果您在node上,它将是全局对象)。

票数 0
EN

Stack Overflow用户

发布于 2018-02-21 19:31:25

添加设置this.b = this.a的构造函数或其他函数

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48904722

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档