场合
我有一个返回的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
});
答案 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"} ]