浏览器返回事件监听
2017-11-02 17:02
162 查看
在进入当前页面的时候向历史站压入该页面,
当监听到返回事件就是popstate的时候,
进行对应的操作,
我们修改历史站的操作pushState不会触发popstate事件, 可见MDN.
$(function(){
pushHistory();
var bool=false;
setTimeout(function(){
bool=true;
},1000);
window.addEventListener("popstate", function(e) {
if(bool)
{
alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能
}
}, false);
});
function pushHistory() {
var state = {
title: "title",
url: "#"
};
window.history.pushState(state, "title", "#")
}
亲测在安卓机中当该页面中还有其他跳转链接的情况时,
再返回该页面时对应的操作会有效(但衍生出对应的一个问题,
历史站里面会多出两个你压入的历史,如果操作后再返回会出现问题),
同时在ios中当返回该页面的时候popState事件也会触发 ,该方法有对应的使用范围, 可酌情使用,
(在B页面使用该方法时,假如B页面内有链接到C页面,c->b时在ios中会触发popState事件,)
当监听到返回事件就是popstate的时候,
进行对应的操作,
我们修改历史站的操作pushState不会触发popstate事件, 可见MDN.
$(function(){
pushHistory();
var bool=false;
setTimeout(function(){
bool=true;
},1000);
window.addEventListener("popstate", function(e) {
if(bool)
{
alert("我监听到了浏览器的返回按钮事件啦");//根据自己的需求实现自己的功能
}
}, false);
});
function pushHistory() {
var state = {
title: "title",
url: "#"
};
window.history.pushState(state, "title", "#")
}
亲测在安卓机中当该页面中还有其他跳转链接的情况时,
再返回该页面时对应的操作会有效(但衍生出对应的一个问题,
历史站里面会多出两个你压入的历史,如果操作后再返回会出现问题),
同时在ios中当返回该页面的时候popState事件也会触发 ,该方法有对应的使用范围, 可酌情使用,
(在B页面使用该方法时,假如B页面内有链接到C页面,c->b时在ios中会触发popState事件,)
相关文章推荐
- 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- JS监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 监听浏览器返回事件,安卓返回事件
- 监听浏览器后退事件,使其转向指定URL,控制某些页面不能返回
- 监听微信端,手机端,ios端的浏览器返回事件,pc端关闭事件
- 监听浏览器返回按钮事件
- 监听手机浏览器的返回按钮事件
- HTML5 浏览器返回按钮/手机返回按钮事件监听
- 监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 微信WEB开发中监听浏览器返回按钮事件强制返回指定页面
- JS 监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 微信浏览器返回刷新,监听微信浏览器返回事件,网页防复制,移动端禁止图片长按和vivo手机点击img标签放大图片
- vue.js 监听到微信浏览器返回事件,关闭浏览器,返回公众号号主体
- 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- IOS微信浏览器返回事件popstate监听
- 很多人都不知道的监听微信、支付宝等移动app及浏览器的返回、后退、上一页按钮的事件方法
- 浏览器窗口关闭事件的监听搜集
- 浮窗WindowManager view返回和Home按键事件监听