请在location.href = url;
下面的评论后建议延迟5秒的方法我尝试过setTimeout和setInterval,但在所有浏览器中都没有正常运行。 我也尝试过睡眠,如下所示:
function sleep(milliseconds) {
var start = new Date().getTime();
for (var i = 0; i < 1e7; i++) {
if ((new Date().getTime() - start) > milliseconds){
break;
}
}
}
console.log(new Date());
console.log('Deleting AdHoc...');
sleep(6000);
console.log(new Date());
但这也不总是有效,也不优雅。
function xToolbar(url, target, name, options, message, height, width) {
if (message == '') {
ok = true
} else {
ok = confirm(message);
}
if (ok == true) {
if (target == 'window') {
if (height != '') {
myTop = (window.screen.height / 2) - ((height / 2) + 10);
myLeft = (window.screen.width / 2) - ((width / 2) + 10);
options = 'height=' + height + ',width=' + width + ',top=' + myTop + ',left=' + myLeft + ',' + options;
}
var popup = window.open('', "Loader", options);
var baseUrls = location.href.split("/")
var baseUrl = baseUrls[0] + "/" + baseUrls[1] + "/" + baseUrls[2] + "/" + baseUrls[3] + "/" + baseUrls[4]
popup.document.writeln('<!--fix for ie7-->')
popup.document.writeln('<!DOCTYPE html>')
popup.document.writeln('<html><head><style>')
popup.document.writeln('body, html {width:100%;height:100%;margin:0;padding:0;background:#fff;color:#333;font:Normal 12px Arial, Helvetica, Sans-Serif;}')
popup.document.writeln('h5 {font-weight:normal; font-size:14px;margin:0 0 10px 0;}')
popup.document.writeln('#outer {width:100%;height:90%;position:relative;}')
popup.document.writeln('#outer[id]{display:table;position: static;}')
popup.document.writeln('#middle {position:absolute;top:50%;width: 100%;text-align:center;}')
popup.document.writeln('#middle[id] {display: table-cell;vertical-align: middle;width: 100%;position: static;}')
popup.document.writeln('#inner {position:relative;top:-50%}')
popup.document.writeln('</style></head><body>')
popup.document.writeln('<div id="outer"><div id="middle"><div id="inner"><h5>Processing your request</h5>')
popup.document.writeln('<img src="' + baseUrl + '/images/toolbar/loader_fan.gif" id="loader" border="0" style="vertical-align:middle"/></div></div></div>')
popup.document.writeln('<script type="text/javascript">')
popup.document.writeln('function load(){')
popup.document.writeln('location.href = "' + baseUrl + "/" + url.replace(/\\/g, '\\\\') + '";')
popup.document.writeln('loader.setAttribute("src","' + baseUrl + '/images/toolbar/loader_fan.gif");};')
popup.document.writeln('</script>')
popup.document.writeln('</body></html>')
popup.document.close();
popup.load();
} else {
if (target == 'frame') {
url += '{amp}EXECUTE_TEMPLATE=$';
var frame = document.getElementById(name);
frame.src = url;
} else {
location.href = url;
// Comment : Please put here some code to delay by 5 seconds
}
}
}
}
提前致谢。
答案 0 :(得分:1)
如果你想延迟页面更改然后使用setTimeout,你说你已经尝试过使用setTimeout,但是没有你向我们展示你如何使用它我会假设你使用它错了
...
else {
setTimeout(function(){
window.location.href=url;
},5000);
}
如果您需要刷新开启者页面,并且弹出窗口是同一个域,那么您可以在容器窗口上设置计时器
...
else {
var opener = window.opener;
if(opener !== null){
opener.setTimeout(function(){
opener.location.href=url;
},5000);
}
}
答案 1 :(得分:0)
如果希望在给定延迟后加载页面,请在location.href链接之前使用setTimeout()。正如帕特里克所提到的,它将在转到其他页面后执行。