前端开发

vue中在某一页面禁掉移动设备的物理返回键

2019-10-18  本文已影响0人  紫气楠楠

1.挂载完成后,判断浏览器是否支持popstate

History 对象包含用户(在浏览器窗口中)访问过的 URL。
History 对象是 window 对象的一部分,可通过 window.history 属性对其进行访问。
通过监听history的pushState来判断页面的状态

mounted(){
            if (window.history && window.history.pushState) {
            // 往历史记录里面添加一条新的当前页面的url
            history.pushState(null, null, document.URL);
            // 给 popstate 绑定一个方法 监听页面刷新
            window.addEventListener('popstate', this.goBack, false);//false阻止默认事件
            }
        },

2.页面销毁时,取消监听。否则其他vue路由页面也会被监听

在页面销毁的生命周期中取消监听

destroyed(){
            window.removeEventListener('popstate', this.goBack, false);//false阻止默认事件
        },

3.将监听操作写在methods里面,removeEventListener取消监听内容必须跟开启监听保持一致,所以函数拿到methods里面写

goBack(){
        history.pushState(null, null, document.URL);
      },

注:history.pushState()方法向浏览器历史添加了一个状态。pushState()方法带有三个参数:一个状态对象、一个标题(现在被忽略了)以及一个可选的URL地址

history.pushState(state, title, url);

state object —— 状态对象是一个由pushState()方法创建的、与历史纪录相关的javascript对象。当用户定向到一个新的状态时,会触发popstate事件。事件的state属性包含了历史纪录的state对象。如果不需要这个对象,此处可以填null

title —— 新页面的标题,但是所有浏览器目前都忽略这个值,因此这里可以填null

URL —— 这个参数提供了新历史纪录的地址。新URL必须和当前URL在同一个域,否则,pushState()将丢出异常。这个参数可选,如果它没有被特别标注,会被设置为文档的当前URL

上一篇 下一篇

猜你喜欢

热点阅读