美文网首页
vue -页面修改未保存,跳转页面的判断处理

vue -页面修改未保存,跳转页面的判断处理

作者: 前端girl吖 | 来源:发表于2018-02-09 15:49 被阅读0次
//全局文件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) {

相关文章

网友评论

      本文标题:vue -页面修改未保存,跳转页面的判断处理

      本文链接:https://www.haomeiwen.com/subject/hbnftftx.html