美文网首页前端开发
vue中在某一页面禁掉移动设备的物理返回键

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

作者: 紫气楠楠 | 来源:发表于2019-10-18 15:29 被阅读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

    相关文章

      网友评论

        本文标题:vue中在某一页面禁掉移动设备的物理返回键

        本文链接:https://www.haomeiwen.com/subject/xwnimctx.html