vue单页面实现当前页面刷新或跳转时提示保存
前言
最近公司vue项目中有一个需求,需要在当前页面刷新或跳转时提示保存并可取消刷新,以防止填写的表单内容丢失。刚开始思考觉得很简单,直接在Router的钩子中判断就好了,会发现还有新的问题存在,浏览器刷新和当前页面关闭的时候无法监听,最终用window.onbeforeunload成功解决,所以用这篇文章简单记录下整个解决过程。
vue-Router的钩子
路由钩子可以分为全局的,单个路由独享的以及组件级别的,解决上述需求只用到了组件级别的路由钩子,所以本文只介绍组件级别的路由钩子,全局的和单个路由独享的路由钩子有需要的同学可以去查看介绍
组件级别路由钩子分为三种
- beforeRouteEnter当成功获取并能进入路由(在渲染该组件的对应路由被 confirm 前)
- beforeRouteUpdate在当前路由改变,该组件被复用时调用
- beforeRouteLeave导航离开该组件的对应路由时调用
具体的介绍和写法如下
const Foo = { template: `...`, beforeRouteEnter (to, from, next) { // 在渲染该组件的对应路由被 confirm 前调用 // 不!能!获取组件实例 `this` // 因为当守卫执行前,组件实例还没被创建 // 可以通过传一个回调给 next来访问组件实例 next(vm => { // 通过 `vm` 访问组件实例 }) }, beforeRouteUpdate (to, from, next) { // 在当前路由改变,该组件被复用时调用 // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候, // 由于会渲染同样的 Foo 组件,组件实例会被复用。而这个钩子就会在这个情况下被调用。 // 可以访问组件实例 `this` // 不支持传递回调(因为this实例已经创建可以获取到,所以没必要) next() }, beforeRouteLeave (to, from, next) { // 导航离开该组件的对应路由时调用 // 可以访问组件实例 `this` // 该导航可以通过 next(false) 来取消。 const answer = window.confirm('Do you really want to leave? you have unsaved changes!') if (answer) { next() } else { // 不支持传递回调(因为this实例已经创建可以获取到,所以没必要) next(false) } } }
注意在刷新当前页面时候,beforeRouteLeave不会触发,它只在进入到其他页面时候才会触发,beforeRouteEnter会在刷新的时候触发。
通过beforeRouteLeave这个路由钩子,我们就可以在用户要离开此页面时候进行提示了!
beforeRouteLeave (to, from, next) { const answer = window.confirm('当前页面数据未保存,确定要离开![image](http://note.youdao./favicon.ico)?') if (answer) { next() } else { next(false) } }
显示的提示框如下
监听浏览器的刷新、页面关闭事件
,这个时候就实现了我们最终的需求了么?并没有,还有一步用window.onbeforeunload监听浏览器的刷新事件,为了防止从当前单页面跳到其他页面之后,在刷新所在新的页面还会触发window上的onbeforeunload的问题,我们不仅要及时的添加onbeforeunload事件,更要及时删除此事件,狼蚁网站SEO优化有两种解决方法可供选择
通过判断它的路由是否是当前需要添加禁止刷新的页面
mounted() { window.onbeforeunload = function (e) { if(_this.$route.fullPath =="/layout/add"){ e = e || window.event; // 兼容IE8和Firefox 4之前的版本 if (e) { e.returnValue = '关闭提示'; } // Chrome, Safari, Firefox 4+, Opera 12+ , IE 9+ return '关闭提示'; }else{ window.onbeforeunload =null } } };
在destory或者beforeDestory的生命周期中直接将onbeforeunload事件置空
mounted() { window.onbeforeunload = function (e) { e = e || window.event; // 兼容IE8和Firefox 4之前的版本 if (e) { e.returnValue = '关闭提示'; } // Chrome, Safari, Firefox 4+, Opera 12+ , IE 9+ return '关闭提示'; } }; destroyed() { window.onbeforeunload = null }
显示的提示框如下
最终,在beforeRouteLeave和onbeforeunload的共同作用下,这个刷新、跳转或者关闭等情况下需要提示保存的需求完美解决!,还有一点点小遗憾,就是onbeforeunload中弹框的自定义提示语设置始终无法生效,大家要是有更加合适的处理办法,欢迎多多交流指正!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程