javascript - Jquery 两个 api 调用来检索两个嵌套 $.each 循环内的不同动态元素

标签 javascript jquery json api loops

我有一个包含顶级元素的 api 链接。对于每个元素,我需要构建第二个 api 调用的结尾,这将为我提供所需的其余元素并将它们拉出。

假设第一个 json 是 (urlphonebrands),其中包含 3 个手机品牌(苹果、三星和诺基亚)。第二个 json 调用取决于每个品牌名称,例如自动构建的 urlphonebrands/Nokia、urlphonebrands/Samsung 或 urlphonebrands/Apple。

我需要循环遍历每个品牌名称以获取颜色、电池生命周期和尺寸等属性。但每种颜色都有另一个选择循环,例如黑色、白色、红色。我的最终结果是,

Apple
    battery life: 
        6h
    color: 
        blue 
        black
Samsung: 
    battery life: 
        6h
    color:
        blue 
        black
Nokia:
    battery life: 
        3h
    color: 
        blue 

虽然我能够成功循环遍历每个顶部元素,但我只能检索第一个项目的最后一个颜色元素,这表明我错误地构建了第二个循环。经过几个小时的研究,我发现我需要一些帮助。这就是我所拥有的,

$.getJSON("urlphonebrands", function(data){

    var brandBlock = data[0]['name'];

    $.each(data, function(index, brandBlock){

        var brand = brandBlock.name;

        $('#table').append('<tr><td>' + brand + '</td></tr>');

        //It works fine until this point

        $.getJSON("phonebrandsurl" + brand, function(data){

            $.each(brand, function (index2, brand){

                var color = data[0].name[0].color;

                $('#table').append('<tr><td>' + color + '</td></tr>');

            });


        });


    });

});

这给了我类似的东西,

Apple
    blue
    blue
Samsung
    blue
    blue
Nokia
    blue

这是第二次 api 调用后的 console.log 输出,

[Object]
0: Object
brand: Array[17]
0: Object
battery life: "6h"
colors: Object
color: "blue"

最佳答案

尝试将第二个 getJSON 包装到匿名函数中并将品牌作为参数传递::

(function(brand){
  $.getJSON('phonebrandsurl' + brand, function(data){
  // ...
}(brand))

关于javascript - Jquery 两个 api 调用来检索两个嵌套 $.each 循环内的不同动态元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14181052/

相关文章:

php - 当用户更改类别时自动填充表单时的 JSON 使用

javascript - 使用按钮在文本区域中输入文本,希望每个条目都从新行开始

javascript - 使用表构建的 Jquery Accordion 菜单

jquery - 多次设置 offset 属性会导致元素跳转到 jQuery 中的新位置

jQuery 对话框 + 禁用

jquery - 如何淡出 1 个 div 并淡入 2 个 div,然后在 10 秒不活动后,再次淡入第一个 div,并淡出 2 个 div?

javascript - alasql-记录更新问题

javascript:为数组中的每个字符串创建自动子字符串

java - 没有注释的 jackson 过滤器属性

java - 如何在android中用逗号解析JSON?