首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JSON for OpenWeatherMap API

JSON for OpenWeatherMap API
EN

Stack Overflow用户
提问于 2014-11-20 14:17:20
回答 1查看 1.3K关注 0票数 0

我正在使用JSON编写一个简单的一页天气应用程序,但在返回的嵌套Openweathermap对象中遇到了一个问题。

下面是JSON的示例:

代码语言:javascript
复制
"cod":"200",
"message":0.1986,
"city":{
    "id":"4781530",
    "name":"Reston",
    "coord":{
        "lon":-77.3545,
        "lat":38.9597
    },
    "country":"United States of America",
    "population":0
},
"cnt":2,
"list":[
    {
        "dt":1416499200,
        "temp":{
            "day":45.3,
            "min":33.48,
            "max":52,
            "night":34.47,
            "eve":50.59,
            "morn":33.48
        },
        "pressure":1015.56,
        "humidity":58,
        "weather":[
            {
                "id":801,
                "main":"Clouds",
                "description":"few clouds",
                "icon":"02d"
            }
        ],
        "speed":9.07,
        "deg":212,
        "clouds":24
    },
    {
        "dt":1416585600,
        "temp":{
            "day":33.04,
            "min":20.55,
            "max":38.86,
            "night":22.87,
            "eve":38.03,
            "morn":24.42
        },
        "pressure":1027.28,
        "humidity":50,
        "weather":[
            {
                "id":800,
                "main":"Clear",
                "description":"sky is clear",
                "icon":"01d"
            }
        ],
        "speed":7.99,
        "deg":301,
        "clouds":0
    }
]

}

我能够成功地遍历obj.list中的第一组值,但是当它到达$.each(obj.list[i].weather[i], function(key,value)循环时,我会得到一个未定义的错误。

我将如何循环嵌套的天气和临时对象,以及为什么我的当前代码给了我一个未定义的错误?我已经包含了代码和Firebug控制台日志。任何帮助都是非常感谢的。

jQuery循环函数

代码语言:javascript
复制
$.each(obj.list, function(i) {
    $.each(obj.list[i], function(key,value) {

        if(typeof value == "object"){
            console.log(key + " is an Object!!");

            if(key=="weather"){
                            console.log("What is i? " + i );
                            console.log(obj.list[i].weather[i]);

                            $.each(obj.list[i].weather[i], function(key,value) {
                                    console.log("weather object " + key + ": " + value );
                            });
            }

        }
        else{
            console.log("outer object " + key + ": " + value );
        }
    });
});

Firebug控制台日志:

代码语言:javascript
复制
outer object dt: 1416499200
scripts.js (line 72)
temp is an Object!!
scripts.js (line 49)
outer object pressure: 1015.56
scripts.js (line 72)
outer object humidity: 58
scripts.js (line 72)
weather is an Object!!
scripts.js (line 49)
What is i? 0
scripts.js (line 59)
Object { id=801, main="Clouds", description="few clouds", more...}
scripts.js (line 60)
weather object id: 801
scripts.js (line 66)
weather object main: Clouds
scripts.js (line 66)
weather object description: few clouds
scripts.js (line 66)
weather object icon: 02d
scripts.js (line 66)
outer object speed: 9.07
scripts.js (line 72)
outer object deg: 212
scripts.js (line 72)
outer object clouds: 24
scripts.js (line 72)
***********
scripts.js (line 103)
outer object dt: 1416585600
scripts.js (line 72)
temp is an Object!!
scripts.js (line 49)
outer object pressure: 1027.28
scripts.js (line 72)
outer object humidity: 50
scripts.js (line 72)
weather is an Object!!
scripts.js (line 49)
What is i? 1
scripts.js (line 59)
undefined
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-11-20 14:33:41

您只需要从每个i列表中请求obj.list[i].weather th元素。您应该在obj.list[i].weather上循环,而不是从它中请求一个元素。因此,对于obj.list[0],您只要求obj.list[0].weather[0]。对于obj.list[1],您只要求obj.list[1].weather[1],它不存在( weather列表只有一个对象,在索引0处)。

您的$.each(obj.list[i].weather[i], ...)循环在obj.list[i].weather[i]上,但您没有在obj.list[i].weather上循环。您需要有两个不同循环变量的东西,比如obj.list[i].weather[j],而不是obj.list[i].weather[i]

代码语言:javascript
复制
    if(typeof value == "object"){
        console.log(key + " is an Object!!");

        if(key=="weather"){
                console.log("What is i? " + i );

                $.each(obj.list[i].weather, function(j) {
                    console.log(obj.list[i].weather[j]);
                    $.each(obj.list[i].weather[j], function(key,value) {
                        console.log("weather object " + key + ": " + value );
                    });
                });
        }

    }

在这里,我们在obj.list[i].weather上添加了一个循环,内部j变量为weather,这样我们就可以得到每个weather列表中的所有项,而不仅仅是一个。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27041771

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档