小编典典

如何枚举 JavaScript 对象的属性?

all

如何枚举 JavaScript 对象的属性?

我实际上想列出所有定义的变量及其值,但我了解到定义变量实际上会创建窗口对象的属性。


阅读 124

收藏
2022-03-03

共1个答案

小编典典

很简单:

for(var propertyName in myObject) {
   // propertyName is what you want
   // you can get the value like this: myObject[propertyName]
}

现在,您不会以这种方式获取私有变量,因为它们不可用。


编辑:[@bitwiseplatypus]是正确的,除非您使用该hasOwnProperty()方法,否则您将获得继承的属性 -
但是,我不知道为什么熟悉面向对象编程的人会期望更少!通常,提出这个问题的人已经受到道格拉斯·克罗克福德的警告,这仍然让我有点困惑。同样,继承是 OO
语言的正常部分,因此是 JavaScript 的一部分,尽管它是原型的。

现在,也就是说,hasOwnProperty() 对于 过滤很有用,但我们不需要发出警告,就好像在获取继承属性时存在危险一样。

编辑 2:@bitwiseplatypus提出了如果有人在您最初​​编写对象(通过其原型)之后的某个时间点向您的对象添加属性/方法时会发生的情况 -
虽然这确实可能导致意外行为,我个人并不完全认为这是我的问题。只是见仁见智。此外,如果我以这样一种方式设计事物,即在我的对象的构造过程中使用原型,但有代码迭代对象的属性并且我想要所有继承的属性,该怎么办?我不会使用hasOwnProperty().
然后,假设有人稍后添加了新属性。如果事情在那个时候表现不好,那是我的错吗?我不这么认为。我认为这就是为什么
jQuery,例如,指定了扩展其工作方式的方法(通过jQuery.extendjQuery.fn.extend)。

2022-03-03