美文网首页
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