我的开发工作主要是做移动端广告的页面,为了留住更多的用户,我们需要监听浏览器的返回键,在用户返回时,弹出弹窗来进一步提供选项来分流客户。(监听关闭键无法自定义弹窗)
使用的方法就是利用pushState(基于jq,改成原生不难,自己动手。。。。)。
先上代码
if (window.history && window.history.pushState) {
//监听浏览器前进或后退
$(window).on('popstate', function () {
$('.outModals').hide() //outModals 弹窗class
$('.outModals').remove()
//当浏览器前进时不弹弹窗
if(location.hash.indexOf('myback')==-1){
stateInit()
}
});
//防止浏览器刷新造成多个历史记录
if(location.hash.indexOf('myback')==-1||location.hash==''){
window.history.pushState(number, null, '#myback');
window.history.forward(1);
}
}else {
//统计下因为兼容问题所存在的用户
addTongJi()
}
function stateInit(){
var html='弹窗的dom class=outModals '
$('body').append(html)
// 继续
$('.outModals_sure').unbind('click').bi