亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

vue實現提示保存后退出的方法?

vue實現提示保存后退出的方法?

SMILET 2018-08-29 15:11:41
vue實現提示保存后退出的方法
查看完整描述

1 回答

?
弒天下

TA貢獻1818條經驗 獲得超8個贊

假設有這樣一個需求,用戶在一個頁面內編輯文字,但是并未點擊保存并且跳轉到了下一個路由。比較好的做法應該是給出一個提示—“您編輯的內容還未保存,是否確認退出?”用戶如果點擊“確定”,那么不保存當前內容直接退出,用戶如果點擊“取消”,則取消本次路由跳轉,繼續留在原來的頁面。

嘗試的錯誤做法

一開始的時候我是想著使用vuex結合vue router的beforeEach導航守衛來實現。代碼如下:

首先在vuex中新增一個狀態值—introduceState

const store = new Vuex.Store({   strict: true, // process.env.NODE_ENV !== 'production', 直接修改state 拋出異常   state: {    ....    introduceState: false,    ....   },   getters: {    introduceState: state => state.currentMenus   },   mutations: {    // 更新introduceState的值    changeIntroduceState (state, value) {     state.introduceState = value    }   }  })

用戶在點擊跳轉到另一個頁面的時候會觸發生命周期函數beforeDestroy,在這個函數中我們可以檢測用戶的編輯內容是否保存,如果尚未保存。

如果內容尚未保存,我們就彈出一個提示框,當用戶選擇取消的時候,就將vuex中的introduceState值更新為true。

</script>  import { mapGetters, mapActions, mapMutations } from "vuex"  export default {   data() {    return {     contentHasSave: false // 記錄用戶是否已經保存內容    }   },   methods: {    ...mapMutations({     changeIntroduceState: changeIntroduceState    })   },   beforeDestory: function(){    if(!contentHasSave){     // 使用element的提示框     this.$confirm('您還未保存簡介,確定需要提出嗎?', '提示', {      confirmButtonText: '確定',      cancelButtonText: '取消',      type: 'warning'     }).then(() => {      // 選擇確定,正常跳轉     })     .catch(() => {      // 選擇取消      this.changeIntroduceState(true)     })    }   }  }  </script>

最后在router的beforeEach的導航守衛里監測from為當前頁面的所有路由跳轉。當state的introduceState為true的時候使用next(false)來取消本次路由跳轉

import Vue from "vue";  import VueRouter from "vue-router";  import routeConfig from "./routes";  import {sync} from "vuex-router-sync";  import store from "../store";  //加載路由中間件  Vue.use(VueRouter)  //定義路由  const router = new VueRouter({   routes: routeConfig,   //mode: 'history'  })  sync(store, router)  router.beforeEach((to, from, next) => {   // 簡介也未提交,取消跳轉   if(from.fullPath === '/adwords/introduce' && store.state.introduceState === 'not-save'){    next(false)   }  })  export default router

這種做法其實是行不通的,因為beforeEach方法的執行其實是在組件beforeDestory的方法之前執行的,也就是說beforeEach執行的時候introduceState的值根本沒有被更新為true。

正確的做法

后來自己去翻vue router的官方文檔,找到了一個絕妙的方法,那就是組件內的導航守衛。

const Foo = {   template: `...`,   beforeRouteEnter (to, from, next) {    // 在渲染該組件的對應路由被 confirm 前調用    // 不!能!獲取組件實例 `this`    // 因為當守衛執行前,組件實例還沒被創建   },   beforeRouteUpdate (to, from, next) {    // 在當前路由改變,但是該組件被復用時調用    // 舉例來說,對于一個帶有動態參數的路徑 /foo/:id,在 /foo/1 和 /foo/2 之間跳轉的時候,    // 由于會渲染同樣的 Foo 組件,因此組件實例會被復用。而這個鉤子就會在這個情況下被調用。    // 可以訪問組件實例 `this`   },   beforeRouteLeave (to, from, next) {    // 導航離開該組件的對應路由時調用    // 可以訪問組件實例 `this`   }  }

上面的描述很清楚,于是我就在組件的js代碼里加了一個beforeRouteLeave方法,然后彈出提示框,實現提示保存后退出的功能。

</script>  export default {   data() {    return {     contentHasSave: false // 記錄用戶是否已經保存內容    }   },    // 組件內導航鉤子,處理未保存退出的情況   beforeRouteLeave: function(to, from , next){    if(this.buttonText === '提交'){     next(false)     this.$confirm('您還未保存簡介,確定需要提出嗎?', '提示', {      confirmButtonText: '確定',      cancelButtonText: '取消',      type: 'warning'     }).then(() => {      // 選擇確定      next()     })    }   }  }  </script>

實現效果如下:

以上這篇vue實現提示保存后退出的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:詳解使用Vue Router導航鉤子與Vuex來實現后退狀態保存vue實現登陸登出的實現示例


查看完整回答
反對 回復 2018-09-22
  • 1 回答
  • 0 關注
  • 981 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號