vue-Router的钩子:
路由钩子可以分为全局的,单个路由独享的以及组件级别的,解决上述需求只用到了组件级别的路由钩子,所以本文只介绍组件级别的路由钩子,全局的和单个路由独享的路由钩子有需要的同学可以去vue-router官网查看介绍:
组件级别路由钩子分为三种:
beforeRouteEnter:当成功获取并能进入路由(在渲染该组件的对应路由被 confirm 前)
beforeRouteUpdate:在当前路由改变,但是该组件被复用时调用
beforeRouteLeave:导航离开该组件的对应路由时调用
具体的介绍和写法如下:
注意:在刷新当前页面时候,beforeRouteLeave不会触发,它只在进入到其他页面时候才会触发,但是beforeRouteEnter会在刷新的时候触发。
通过beforeRouteLeave这个路由钩子,我们就可以在用户要离开此页面时候进行提示了!
显示的提示框如下:
监听浏览器的刷新、页面关闭事件
但是,这个时候就实现了我们最终的需求了么?并没有,还有一步:用window.onbeforeunload监听浏览器的刷新事件,当然为了防止从当前单页面跳到其他页面之后,在刷新所在新的页面还会触发window上的onbeforeunload的问题,我们不仅要及时的添加onbeforeunload事件,更要及时删除此事件,下面有两种解决方法可供选择:
通过判断它的路由是否是当前需要添加禁止刷新的页面
在destory或者beforeDestory的生命周期中直接将onbeforeunload事件置空
显示的提示框如下:
总结
最终,在beforeRouteLeave和onbeforeunload的共同作用下,这个刷新、跳转或者关闭等情况下需要提示保存的需求完美解决!但是,还有一点点小遗憾,就是onbeforeunload中弹框的自定义提示语设置始终无法生效,大家要是有更加合适的处理办法,欢迎多多交流指正!