防止页面不断重新加载
Prevent page reloading continuously
我在函数内使用window.history.pushState({)
。这工作正常,如预期的那样。下面是一个例子:
$('#go_btn').click(function(){
if ($('.green')) {
var newurl = "cutomurl.html";
if(newurl!=window.location){
window.history.pushState({path:newurl},'',newurl);
}
return false;
}
});
,我也得到了下面的代码,能够刷新页面时,newurl
是由$('#go_btn')
按钮触发。
$(window).on('popstate', function(){
location.reload(true);
});
在桌面版本上我似乎没有任何问题。但当我试图在iPad上加载这个页面时,它会不断地重新加载这个页面。那么,如何停止连续重新加载并仅在触发window.history.pushState({path:newurl},'',newurl);
时刷新页面呢?
注意,仅仅调用history.pushState()或history.replaceState()不会触发popstate事件。只是触发popstate事件通过执行浏览器操作,例如单击后退按钮(或返回)在JavaScript中调用history.back()。事件只会被触发当用户在同一条目的两个历史条目之间导航时文档。
浏览器倾向于在页面加载时以不同的方式处理popstate事件。Chrome (v34之前)和Safari总是在页面上发出popstate事件.
根据mozilla Developer Network
https://developer.mozilla.org/en-US/docs/Web/API/WindowEventHandlers/onpopstate
Safari总是在页面加载时发出popstate事件。这意味着
- 您的页面加载
- Popstate事件发生
- location.reload()执行
- 正在重复
:请阅读有关操作浏览器历史记录的文档。https://developer.mozilla.org/en-US/docs/Web/Guide/API/DOM/Manipulating_the_browser_history
看起来你误解了一些功能。
有一个#go_btn按钮。当你点击它时,你想要一个页面:
1。重载
使用location.reload()
if (newurl != window.location)
{
// window.history.pushState({path:newurl},'',newurl);
location.reload(true);
}
2。导航到新的URL
使用location.href
。将在当前窗口中打开新页面。
if (newurl != window.location)
{
// window.history.pushState({path:newurl},'',newurl);
location.href = newurl;
}
3。不用做任何事情就可以改变浏览器历史记录和地址栏中的URL
使用window.history.pushState()
或window.history.replaceState()
。它不会打开或重新加载新页面。它只在你不打算导航,但希望用户获得新的URL(方便浏览,历史或收藏)时使用。
if (newurl!=window.location)
{
window.history.pushState({path:newurl},'',newurl);
}
在所有这三种情况下,您都不需要popstate
事件。它被用于其他目的。
你需要哪一个?这取决于你的任务。
无论如何,将它们中的任何两个一起使用都不是不合逻辑和无用的。如果要刷新页面,推送历史状态的原因是什么?然后导航到它
- 创建新数据和加载现有数据需要单独的视图吗
- 钛 - HTTPClient:打开新的控制器加载
- 保持 JavaScript 在浏览器控制台中运行,即使在新的页面加载之后也是如此
- 路由到新页面时加载不起作用
- 如何在新窗口完成加载后执行某些内容
- 使用新标题重新加载 html 页面
- Primefaces在打开新页面时加载数据消息
- Wordpress音频播放器和平滑状态.在新页面重新加载播放器时调用什么回调函数
- 用新数据重新加载renderer3d
- 文本不被渲染后,新的页面加载- JQuery移动
- 需要在新标签中加载pdf/doc文件,而不是下载,只是想在浏览器中阅读
- 用新参数重新加载页面
- Js和CSS不检测新页面何时加载
- 在新页面上加载一个flash视频,它在上一页上的位置
- 在新窗口中加载代码编写器视图
- 在控制台中使用新脚本重新加载页面
- 如何在加载新页面后加载AJAX数据
- 如何使用jQuery在新窗口中加载页面,然后关闭它们
- Jquery没有看到新的HTML加载到对话框中
- 无法用新值重新加载JGrid