在不知道属性名称的情况下访问JavaScript的对象属性

时间:2013-05-15 23:09:21

标签: javascript object properties

场合

我有一个返回的JSON对象。以下是一个例子。此特定示例中的who可以更改为所需的任何属性名称。例如,下次这将是name而不是who

 [{"who":"Arthur"},{"who":"Craig"},{"who":"Dan"},{"who":"Daniel"},{"who":"Frank"},{"who":"Ian"},{"who":"jamie"},{"who":"Jason"},{"who":"jaz"},{"who":"Liam"},{"who":"Paul"},{"who":"Shaun"},{"who":"Wayne"}]

问题

在我的JS中,我需要能够引用属性并访问其数据而不使用其名称,因为名称将始终不同。

我尝试了什么

data.forEach(function(m){
    console.info(m); // Object { who="Craig"}
    console.info(m.who); // Craig, as expected
    console.info(m[0]); // now not sure who to get it if who changes to name
});

3 个答案:

答案 0 :(得分:26)

Object.keys(m)[0]应返回对象m中的第一个可枚举属性名称。

因此,如果m = {"who": "Arthur"};,那么m[Object.keys(m)[0]]将是"Arthur"

https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Object/keys


或者:Object.values(m)[0]。见Object.values

答案 1 :(得分:2)

如果你总是希望这些对象只有一个属性,你可以这样做:

var name, person;
for (person in data) {
    for (name in data[person]) {
        console.log(data[person][name]);
    }
}

这将枚举数据中每个人的每个属性。因为每个人只有一个属性(我假设),它只会枚举一个属性并停止,允许您使用该属性而不管其名称。

答案 2 :(得分:2)

您还可以使用for in循环:

data.forEach( function ( m ) {

  for ( var key in m ) {

    console.log( key ); // "who"
    console.log( m[key] ); // "Arthur"

  }

});

上述内容也适用于对象中的多个key: value对,即:

[ {"who":"Arthur","who":"Fred"} ]