【发布时间】:2020-09-26 02:42:07
【问题描述】:
我使用带有 openweathermap API 的 HTML、CSS、JS(不是 jQuery)创建 Web 应用程序。 我想根据天气改变背景。
但我已经尝试了很多,但没有成功。 js文件是一个main.js文件。
这是JS代码。
function displayResults(weather) {
var city = document.querySelector(".city");
city.innerHTML = weather.name + ", " + weather.sys.country;
let now = new Date();
let date = document.querySelector(".location .date");
date.innerHTML = dateBuilder(now);
let temp = document.querySelector(".current .temp");
temp.innerHTML = Math.round(weather.main.temp - ChangeTemp).toFixed(0) + "°C";
var weather_el = document.querySelector(".current .weather");
weather_el.innerHTML = weather.weather[0].main;
var weatherinfo = weather.weather[0].main;
let hilow = document.querySelector(".hi-low");
hilow.innerText =
"Low and High Temp: " +
Math.round(weather.main.temp_min - ChangeTemp) +
" °C / " +
Math.round(weather.main.temp_max - ChangeTemp) +
" °C";
}
function backgroundChange(weather) {
var imgs = document.getElementById("allbody");
imgs.style.backgroundImage = "url(background.gif)";
if (weatherinfo == Rain) {
imgs.style.backgroundImage = "url(rain3.gif)";
} else if (weatherinfo == Clouds) {
imgs.style.backgroundImage = "url(cloud.gif)";
} else if (weatherinfo == Clear) {
imgs.style.backgroundImage = "url(sky3.gif)";
} else {
imgs.style.backgroundImage = "url(background.gif)";
}
}
不工作功能背景更改。
这是 HTML 代码。
<div id='allbody' class="app" style="background-image: url(background.gif);">
<div>
<header>
<input type="text" autocomplete="off" class="search-box" placeholder="Please enter the location."/>
</header>
<main>
<section class="location">
<div class="city">Location, Country</div>
<div class="date">Today date info</div>
</section>
<div class="current">
<div class="temp"><span>Temp (°C)</span></div>
<div id="wdata" class="weather">Weather</div>
<div class="hi-low">Low and High Temp</div>
</div>
...
如何根据天气改变背景图片?
谢谢
【问题讨论】:
-
是
Rain、Clouds等...是对您的代码中未包含的变量的引用吗?也没有调用backgroundChange,所以我不确定你缺少什么代码。 -
@Chase 如何重新评论?抱歉,我对此一无所知。 Rain can Clouds from html 结果。所以它不是可变的。那我该怎么办?
-
不完整,只是检查一下。如果完成,我会在这里添加。
标签: javascript html background-image weather openweathermap