首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >获取API css-loader

获取API css-loader
EN

Stack Overflow用户
提问于 2019-04-11 21:13:38
回答 1查看 277关注 0票数 1

我正在使用fetch API来访问JSON对象。

我的问题是,如何在实际数据显示之前实现css加载器。以及如何知道数据已显示。

这是我尝试过的:

代码语言:javascript
复制
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);

我的加载器看起来像这样:

代码语言:javascript
复制
.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看起来像这样:

代码语言:javascript
复制
<div class="tempVal">
    <div class="loader"></div>
    <div id="temp1"></div>
</div>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-11 21:20:08

您已经在这样做了,但是将getElementById用于一个类(它仅用于it)。当你不确定这些事情的时候,确保你确实得到了你想要的元素,例如使用debugger语句或console.log(document.getElementById("loader"))

获取一个可以处理所有css选择器的querySelector类:

document.querySelector('.loader').style.display = 'none'

注意如果你有多个同名的类,它将得到第一个类。你不需要在两个.then中重复它。

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

https://stackoverflow.com/questions/55633360

复制
相关文章

相似问题

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