//全局文件main.js
const router = new VueRouter({
routes
})
router.beforeEach((to, from, next) => {
if(from.path == "...从某个页面跳转...") {
if(confirm('编辑内容未保存,是否离开?')) {
next()
}else {
next(false)
}
//1. next() 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是confirm的
//2. next('/') 或者next({path:'/'}) 跳转到一个不同的地址,当前的好行中断,然后进行一个新的导航
//3. next(false) 中断当前的导航
}else {
next() //必须加
}
})
// init vue
const vm = new Vue({
store,
router,
render: h => h(App)
}).$mount('#app')
本地实现:某某信息录入页面,修改过程中点击导航栏的链接,确认是否未保存内容也跳转页面。
可能存在的问题:
- 如果录入提交成功后会自动跳转到**列表页。只有上面的代码,仍会弹出那个confirm弹框。
我们可以通过全局变量,vuex状态共享定一个变量isEditted 默认false,然后在全局文件里路径判断时加上这个变量 , 只有该录入页面有任何修改时才设为true 才会出现该弹框
if(from.path == "...从某个页面跳转..." && store.state.moduleA.isEditted) {