vue中监听返回键
问题:在项目中,我们常常有需求,当用户在填写表单时,点击返回的时候,我们希望加一个弹窗,确认离开吗,确认将保存为草稿
解决方案:利用 h5的 pushstate(个人理解为增加页面栈)特性与onpopup事件
分析:pushstate 从该方法名我们可以知道 是增加某种状态,会为history对象的length增加长度, 点击返回键的时候会触发onpopup事件(可以联想到 pop其实是数组删除的最后一个元素,符合 ‘栈’ 的思想);
onpopup触发返回上一页,而 pushstate仅仅是从url上进行了改变,不会校验url的内容,页面不会改变,加入当前页面为 xxx/b.html,此时pushstate(null,null,'a.html'),可以发现 url变了,而页面的内容并没有改变,我们可以通过这来造成一种无法返回的假象
实施:
//注意:dialog是一款弹窗的插件
mounted: function() {
//当前页面挂载的时候调用 返回键的监听方法
this.listeningback()
}
//当页面销毁的时候我们也要将事件监听销毁,以免影响其他内容
destroyed:function(){
window.onpopstate = null
},
methods:{
//监听返回键
listeningback() {
var that = this;//window.onpopstate方法指向window,所以要储存一下当前的vue实例
let route = '上一页';//根据业务逻辑的上一页决定
window.onpopstate = function() {
//将当前页面window.location.href 放入页面栈当中
history.pushstate({}, null, window.location.href);
dialog.alert({
title: '标题',
message: '确认返回吗,你所填写的内容将保存为草稿'
}).then(() => {
that.$router.push({
path:route
})
}).catch(
console.log('取消返回,留在当前页面')
);
}
},
}
下一篇: 设计模式-行为型-解释器模式
推荐阅读
-
Android onKeyDown监听返回键无效的解决办法
-
Android中双击返回键退出应用实例代码
-
vue 弹窗时 监听手机返回键关闭弹窗功能(页面不跳转)
-
解决vue中监听input只能输入数字及英文或者其他情况的问题
-
vue App.vue中的公共组件改变值触发其他组件或.vue页面监听
-
详解vue中this.$emit()的返回值是什么
-
Vue使用watch监听一个对象中的属性的实现方法
-
解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
-
Android应用中Back键的监听及处理实例
-
vue中的watch监听数据变化及watch中各属性的详解