是否可以将对象属性名称作为字符串获取
person = {};
person.first_name = 'Jack';
person.last_name = 'Trades';
person.address = {};
person.address.street = 'Factory 1';
person.address.country = 'USA';
我想像这样使用它:
var pn = propName( person.address.country ); // should return 'country' or 'person.address.country'
var pn = propName( person.first_name ); // should return 'first_name' or 'person.first_name'
注意:这段代码正是我要找的。我知道这听起来甚至很愚蠢,但事实并非如此。
这就是我想用它做的。
HTML
person = {};
person.id_first_name = 'Jack';
person.id_last_name = 'Trades';
person.address = {};
person.address.id_address = 'Factory 1';
person.address.id_country = 'USA';
extPort.postMessage
(
{
message : MSG_ACTION,
propName( person.first_name ): person.first_name
}
};
———————- 答案---——————-
得到它感谢伊布。他指出了正确的方法,我使用了递归函数
var res = '';
function propName(prop, value) {
for (var i in prop) {
if (typeof prop[i] == 'object') {
if (propName(prop[i], value)) {
return res;
}
} else {
if (prop[i] == value) {
res = i;
return res;
}
}
}
return undefined;
}
var pn = propName(person, person.first_name); // returns 'first_name'
var pn = propName(person, person.address.country); // returns 'country'
演示:http: //jsbin.com/yabal/1/edit
原文由 CLiFoS 发布,翻译遵循 CC BY-SA 4.0 许可协议
是的,你可以,稍作改变。
现在您可以像这样获得值:
注意 我不确定它可以用来做什么。
其他 Note 不能很好地处理嵌套对象。但话又说回来,请看第一个音符。