我有一个Google Web应用程序显示一个HTML仪表板,其中包含通过AJAX提取的数据。电子表格是使用Google表单填充的,我希望每10秒钟左右更新一次数据(模拟选举结果),以便投票通过,以便老师可以看到实时结果。
这是应用程序的相关部分:
代码
function getData() {
var sheet = ss.getSheets()[3];
var data = sheet.getDataRange().getValues();
Logger.log(data);
return JSON.stringify(data);
}
function doGet() {
return HtmlService
.createTemplateFromFile("index")
.evaluate();
}
HTML模板
function popularVote(data) {
var getDivs = document.getElementsByClassName("percent");
var data = JSON.parse(data);
for(var j=0;j<getDivs.length;j++) {
getDivs[j].textContent = ((data[j][1]/data[j][2]) * 100).toFixed(1) + "%";
}
}
google.script.run.withSuccessHandler(popularVote).getData();
<div class="card" id="popular">
<div class="cand" id="cand1">
<h2>Candidate:</h2><span class="percent">Loading...</span>
</div>
<div class="cand" id="cand2">
<h2>Candidate:</h2><span class="percent">Loading...</span>
</div>
<div class="cand" id="cand3">
<h2>Candidate:</h2><span class="percent">Loading...</span>
</div>
</div>
我无法弄清楚的是实际提取数据的原因。成功处理程序是否正在轮询服务器?还是客户端脚本?我应该在哪里包含Utilities.sleep
或类似内容?
似乎此行从电子表格中获取数据:
google.script.run.withSuccessHandler(popularVote).getData();
您可以尝试将此行包装在setInterval中,以便每十秒钟调用一次:
setInterval(function(){
google.script.run.withSuccessHandler(popularVote).getData();
}, 10000);
setInterval可能也有等效的Google Apps脚本。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句