这个问题在这里已有答案:
嗨我正在用JSON为我自己做一点运动,我正在尝试从URL中重新获取数据
http://api.openweathermap.org/data/2.5/weather?q=miami
查询没有问题,数据返回我甚至可以用innerHTML将其写入html文件 . 但是,如果我想访问JSON数据的密钥,它表示未定义 . 但是,如果我给变量JSON代码与Formating它工作,我甚至可以访问键我不明白 .
/* Here Goes Your Ajax Code */
var server;
if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
server = new XMLHttpRequest();
} else {// code for IE6, IE5
server = new ActiveXObject("Microsoft.XMLHTTP");
}
var city = "Düsseldorf"
var userInput = document.getElementById("userInput");
userInput.addEventListener("change", myFunction);
var weatherUrl = "http://api.openweathermap.org/data/2.5/weather?q="+city;
server.open("POST", weatherUrl , false);
server.send();
var weather= JSON.parse(server.responseText);
document.getElementById("errorMe").innerHTML = weather;
city = weather.name;
document.getElementById("city").innerHTML = city;
function myFunction() {
city = document.getElementById("userInput").value;
weatherUrl = "http://api.openweathermap.org/data/2.5/weather?q="+city;
server.open("POST", weatherUrl , false);
server.send();
document.getElementById("myDiv").innerHTML = weather= JSON.parse(server.responseText);
weather= JSON.parse(server.responseText);
if(weather.cod == 404){
document.getElementById("myDiv").innerHTML = "<p>You typet a city that does not Exist!</p>";
}else{
document.getElementById("myDiv").innerHTML = weather;
}
}
1 回答
我猜测当你使用从服务器返回的版本时,它只是文本 - 你需要使用
将它变成一个随后可以访问属性的对象 .