我正在使用fetch API来访问JSON对象。
我的问题是,如何在实际数据显示之前实现css加载器。以及如何知道数据已显示。
这是我尝试过的:
var startSevenDaysInterval = (new Date).getTime();
var endSevenDaysInterval = startSevenDaysInterval - 604800000;
function fetchData2() {
fetch('https://vannovervakning.com/api/v1/measurements/3/' + endSevenDaysInterval + '/' + startSevenDaysInterval + '/')
.then(function (response) {
if(response === 404){
document.getElementById("loader").style.display = 'none';
}
return response.json();
})
.then(function (data) {
document.getElementById("loader").style.display = 'none';
printTemperature(data);
});
}
function printTemperature(data) {
var html = "<h5>";
html += data.data["TEMPERATURE"][0].value;
html += "</h5>";
document.getElementById('temp1').innerHTML = html;
}
setInterval(function () {
fetchData2();
}, 1000);我的加载器看起来像这样:
.loader {
border: 4px solid #f3f3f3; /* Light grey */
border-top: 4px solid #e0e0e0;
border-radius: 30px;
width: 30px;
height: 30px;
animation: spin 1s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}我的HTML看起来像这样:
<div class="tempVal">
<div class="loader"></div>
<div id="temp1"></div>
</div>发布于 2019-04-11 21:20:08
您已经在这样做了,但是将getElementById用于一个类(它仅用于it)。当你不确定这些事情的时候,确保你确实得到了你想要的元素,例如使用debugger语句或console.log(document.getElementById("loader"))。
获取一个可以处理所有css选择器的querySelector类:
document.querySelector('.loader').style.display = 'none'
注意如果你有多个同名的类,它将得到第一个类。你不需要在两个.then中重复它。
https://stackoverflow.com/questions/55633360
复制相似问题