Javascript JsON获取对象成员名称

时间:2010-10-19 07:41:48

标签: javascript jquery html json

这可能是一个非常基本的问题,但似乎找到答案并不容易。 我有一个Json,或多或少就像:

languages = {
"aa":{"iso639-2T":"aar","family":"Afro-Asiatic","labels":{"language_names":["Afar"],"native_names":["Afaraf"]}},
"ab":{"iso639-2T":"abk","family":"Northwest Caucasian","labels":{"language_names":["Abkhaz"],"native_names":["\u0430\u04a7\u0441\u0443\u0430"]}},
"af":{"iso639-2T":"afr","family":"Indo-European","labels":{"language_names":["Afrikaans"],"native_names":["Afrikaans"]}}, etc...etc... }

如果你看到上面的json,那么语言变量中就有几个语言对象。每个语言对象都有自己的名称作为标识符(“aa”,“ab”,“af”)

那么,我的问题是,如果我想在html中列出所有这些语言,如何获取这些标识符(“aa”,“ab”,“af”)?例如。如果我想创建一个组合框(<option value="aa">Afar</option><option value="ab">Abkhaz</option><option value="af">Afrikaans</option>

实际上我想要实现的是这样的(在php中)

$sampleArray = Array("aa" => "Afar", "ab" => "Abkhaz", "af" => "Afrikaans"); foreach($sampleArray as $id => $value){ /* I can get the id from $id* / }

在java脚本中,我的json是否有类似上面的php语法的解决方案?

PS。如果你想知道我为什么不使用数组 - 我只是觉得抓住某些语言对象会更容易(我只是做类似:languages["af"]来获取afrikaans语言)而不是我应该这样做:loop通过整个语言对象并逐个检查id是否是我想要的,然后返回它。 - 如果你们有更好的想法,你可以给我另一个建议:)

最诚挚的问候,

5 个答案:

答案 0 :(得分:6)

这应该做你想要的......

看到他们

for (var lang in languages)
  alert(lang + ' : ' + languages[lang].labels.language_names[0]);

将它们放入DOM

var $select = $('selector to your select element');
for (var lang in languages)
  $select.append('<option value="'+lang+'">' + languages[lang].labels.language_names[0] + '</option>');

http://www.jsfiddle.net/EsJAh/

的工作代码

答案 1 :(得分:3)

您可以使用“for”

for (var key in languages)
{
 alert(key);
}

答案 2 :(得分:2)

var data = new Array();
for(var lang in languages) {
    data[lang] = languages[lang];
}

答案 3 :(得分:2)

你有没有尝试过:

languages['af'].labels.language_names[0]

它将返回南非荷兰语

答案 4 :(得分:0)

如果您正在使用jquery,那么您可以实际执行此操作:

$.each( languages, function(k, v){
        alert( "Key: " + k + ", Value: " + v );
        // value is your particular language object based on k variable
});

:)