构建一个简单的天气应用程序,我得到了一些草率的香草JS。显然应该用jQuery编写。转换它,我在页面的4天预测部分遇到了一些麻烦。在纯JS中,我只是针对ID并从JSON对象中提取值。使用jQuery,我试图使用$ .each来迭代现在的一系列类,并注入相同的值。
我总是最终在元素中获得相同的一系列值,这对我没有任何意义。当我将值记录到控制台时,它们似乎正在迭代。每天的预测显示在控制台中,并按顺序显示。它们并没有出现在它们应该使用的元素中,即使脚本似乎在迭代元素,但是出现了问题。
在笔中你可以找到我尝试过的其他一些东西,包括在循环中构建HTML元素。
$(document).ready(function(){
var url="http://api.wunderground.";
$.getJSON(url,function(response){
var current = response.current_observation;
var forecast = response.forecast.simpleforecast;
$("#city").html(current.display_location.city + ",");
$("#state").html(current.display_location.state);
$("#weather").html(current.weather);
$("#temp").html(current.feelslike_f + "\u00B0");
$("#lastUpdate").html(current.observation_time);
$.each(forecast.forecastday, function(i){
var foreshort = forecast.forecastday[i];
$(".dayName:nth-of-type(" + i + "n)").text(foreshort.date.weekday);
$(".cond:nth-of-type(" + i + "n)").text(foreshort.conditions);
$(".hi:nth-of-type(" + i + "n)").text(foreshort.high.fahrenheit);
$(".lo:nth-of-type(" + i + "n)").text(foreshort.low.fahrenheit);
console.log(foreshort.date.weekday);
console.log(foreshort.conditions);
console.log(foreshort.high.fahrenheit);
console.log(foreshort.low.fahrenheit);
console.log(i);
}); //end .each
}); //end getJSON
}); //end ready
答案 0 :(得分:0)
您不想在此处使用nth-of-type
selector(各自的父的第n个孩子与相同的元素名称“)。您希望.eq()
method获取所选元素的第n个。
var daynames = $(".dayName"),
conds = $(".cond"),
his = $(".hi"),
los = $(".lo");
$.each(forecast.forecastday, function(i){
dayNames.eq(i).text(this.date.weekday);
conds.eq(i).text(this.conditions);
his.eq(i).text(this.high.fahrenheit);
los.eq(i).text(this.low.fahrenheit);
console.log(this, i);
});
答案 1 :(得分:0)
您的选择器出现错误,请尝试以下操作:
$(".dayName").eq(i).text(foreshort.date.weekday);
$(".cond").eq(i).text(foreshort.conditions);
$(".hi").eq(i).text(foreshort.high.fahrenheit);
$(".lo").eq(i).text(foreshort.low.fahrenheit);
答案 2 :(得分:0)
您误解了nth-of-type
选择器。它选择父类中第n个子类型的元素。在您的情况下,它不是dayName
,cond
en temps
,而是他们的父亲day
,即第n个孩子。所以你当前的选择器
.dayName:nth-of-type(" + i + "n)
应该成为
.day:nth-of-type(" + i + "n) .dayName
或者用简单的英语:“第n天的日期/日期。”
这样该块就可以成为:
$(".day:nth-of-type(" + i + "n) .dayName").text(foreshort.date.weekday);
$(".day:nth-of-type(" + i + "n) .cond").text(foreshort.conditions);
$(".day:nth-of-type(" + i + "n) .hi").text(foreshort.high.fahrenheit);
$(".day:nth-of-type(" + i + "n) .lo").text(foreshort.low.fahrenheit);