加载文档后,我想刷新一次页面。所以我写了这段代码。它工作正常,但是一次又一次地调用。因为我正在刷新同一页面。但我想清除一次执行后的间隔。
function refreshPage(){
document.location.reload(true);
alert('page is refresh.');
}
var interval = setTimeout('refreshPage()', 3000);
最佳答案
如果您希望它仅工作一次,无论延迟如何,您都可以将您所做的事实存储在localStorage中:
function refreshPage(){
alert('page will refresh.');
document.location.reload(true);
localStorage['refreshDone'] = 'yes';
}
if (!localStorage['refreshDone']) {
setTimeout('refreshPage()', 3000);
}
但是您不能简单地清除超时或间隔,因为每次重新加载页面时窗口变量都会丢失。
由于我不确定您的确切目标,以防万一您想刷新(如果最近未完成),可以将时间戳存储在localStorage中:
function refreshPage(){
alert('page will refresh.');
document.location.reload(true);
localStorage['refresh'] = new Date().getTime();
}
var lastTimeRefresh = parseInt(localStorage['refresh']||'0', 10);
if (new Date().getTime() - lastTimeRefresh > 30*60*1000) { // 30 minutes
setTimeout('refreshPage()', 3000);
}