vue项目使用js监听浏览器关闭、刷新及后退事件的方法
更新时间:2023年09月05日 11:43:15 作者:今天不要写bug
这篇文章主要给大家介绍了关于vue项目使用js监听浏览器关闭、刷新及后退事件的相关资料,文中通过代码介绍的非常详细,对大家学习或者使用vue具有一定的参考借鉴价值,需要的朋友可以参考下
一、业务场景:
在项目的某些页面中,在执行某些接口调用过程的时候,如果用户选择刷新、关闭或者后退浏览器。有可能会造成接口被阻断,所以可能你会需要js监听浏览器关闭、刷新、后退事件,在进行这些操作的时候给个提示。如下图:


二、实现方式
1、监听浏览器关闭、刷新,给出提示
methods: {
handleBeforeUnload(event) {
// 兼容火狐的做法
event.preventDefault()
event.returnValue = ''
// 展示提示消息
// (这里其实修改默认提示语是不生效的,不过我的业务场景不需要修改默认提示语
// 我也没找到能修改的方法,有大佬知道的话麻烦告知)
const message = '确定要离开吗?'
event.returnValue = message
return message
}
},
mounted() {
window.addEventListener('beforeunload', this.handleBeforeUnload)
window.addEventListener('unload', this.handleBeforeUnload)
},
destroyed() {
window.removeEventListener('beforeunload', this.handleBeforeUnload)
window.removeEventListener('unload', this.handleBeforeUnload)
},2、监听浏览器后退,给出提示
methods:{
onPopState(e) {
// 监听到浏览器回退事件(这里提示用的confirm,是可以自定义的)
if (confirm('离开当前页面数据可能会丢失,您确定离开当前页面吗?')) {
// 点击确定回退
window.removeEventListener('popstate', this.onPopState)
window.history.go(-1)
} else {
// 点击取消不回退
window.history.pushState(null, null, window.location.href)
}
},
},
mounted() {
// 添加 popstate 事件监听
window.history.pushState(null, null, window.location.href);
window.addEventListener('popstate', this.onPopState);
},
beforeDestroy() {
// 在组件销毁前,移除 popstate 事件监听
window.removeEventListener('popstate', this.onPopState)
}总结
到此这篇关于vue项目使用js监听浏览器关闭、刷新及后退事件的文章就介绍到这了,更多相关vue用js监听浏览器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue3中Watch、Watcheffect、Computed的使用和区别解析
Watch、Watcheffect、Computed各有优劣,选择使用哪种方法取决于应用场景和需求,watch 适合副作用操作,watchEffect适合简单的自动副作用管理,computed 适合声明式的派生状态计算,本文通过场景分析Vue3中Watch、Watcheffect、Computed的使用和区别,感兴趣的朋友一起看看吧2024-07-07
解决element-ui el-drawer抽屉el-dialog弹框关闭优化demo
这篇文章主要为大家介绍了解决element-ui el-drawer抽屉el-dialog弹框关闭优化demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪<BR>2023-06-06
vue el-form-item如何添加icon和tooltip
这篇文章主要介绍了vue el-form-item如何添加icon和tooltip问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-10-10
基于 vue-skeleton-webpack-plugin 的骨架屏实战
这篇文章主要介绍了基于 vue-skeleton-webpack-plugin 的骨架屏实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08


最新评论