这可能是一个非常基本的问题,但似乎找到答案并不容易。 我有一个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是否是我想要的,然后返回它。 - 如果你们有更好的想法,你可以给我另一个建议:)
最诚挚的问候,
和
答案 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>');
的工作代码
答案 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
});
:)