欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實現(xiàn)提示保存后退出的方法

 更新時間:2018年03月15日 11:14:04   作者:小迪的博客  
下面小編就為大家分享一篇vue實現(xiàn)提示保存后退出的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

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

嘗試的錯誤做法

一開始的時候我是想著使用vuex結(jié)合vue router的beforeEach導(dǎo)航守衛(wèi)來實現(xiàn)。代碼如下:

首先在vuex中新增一個狀態(tài)值—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
  }
 }
})

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

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

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

最后在router的beforeEach的導(dǎo)航守衛(wèi)里監(jiān)測from為當(dāng)前頁面的所有路由跳轉(zhuǎn)。當(dāng)state的introduceState為true的時候使用next(false)來取消本次路由跳轉(zhuǎn)

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) => {
 // 簡介也未提交,取消跳轉(zhuǎn)
 if(from.fullPath === '/adwords/introduce' && store.state.introduceState === 'not-save'){
  next(false)
 }
})
export default router

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

正確的做法

后來自己去翻vue router的官方文檔,找到了一個絕妙的方法,那就是組件內(nèi)的導(dǎo)航守衛(wèi)。

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

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

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

實現(xiàn)效果如下:

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

相關(guān)文章

  • Vue+ElementUI啟動vue卡死的問題及解決

    Vue+ElementUI啟動vue卡死的問題及解決

    這篇文章主要介紹了Vue+ElementUI啟動vue卡死的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 關(guān)于vue路由緩存清除在main.js中的設(shè)置

    關(guān)于vue路由緩存清除在main.js中的設(shè)置

    今天小編就為大家分享一篇關(guān)于vue路由緩存清除在main.js中的設(shè)置,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue中點擊下載圖片的實現(xiàn)方法

    vue中點擊下載圖片的實現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于vue中點擊下載圖片的實現(xiàn)方法,在Vue的模板中,我們可以將下載屬性綁定至或元素上,用來實現(xiàn)點擊下載,需要的朋友可以參考下
    2023-08-08
  • vue基于input實現(xiàn)密碼的顯示與隱藏功能

    vue基于input實現(xiàn)密碼的顯示與隱藏功能

    這篇文章主要介紹了vue基于input實現(xiàn)密碼的顯示與隱藏功能,文末給大家介紹了vue?如何實現(xiàn)切換密碼的顯示與隱藏效果,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    這篇文章主要為大家介紹了vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue elementUI el-form 數(shù)據(jù)無法賦值且不報錯的問題及解決方法

    vue elementUI el-form 數(shù)據(jù)無法賦值且不報錯的問題及解決方法

    vue項目中使用elementUI的el-form組件,里面有部分后端數(shù)據(jù)遍歷的字段和部分確定的字段,遇到個問題遍歷的字段可以修改值但是確定的幾個字段無法修改值,下面小編給大家分享vue elementUI el-form 數(shù)據(jù)無法賦值且不報錯的問題及解決方法,感興趣的朋友一起看看吧
    2023-12-12
  • vue編寫的功能強(qiáng)大的swagger-ui頁面及使用方式

    vue編寫的功能強(qiáng)大的swagger-ui頁面及使用方式

    swagger是一種標(biāo)準(zhǔn)的數(shù)據(jù)格式的定義,對于不同語言進(jìn)行實現(xiàn)一些注解API式的東西,能快速生成這種描述restful格式的api信息的json串,本文給大家詳細(xì)介紹vue編寫的功能強(qiáng)大的swagger-ui頁面,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • 解決Idea、WebStorm下使用Vue cli腳手架項目無法使用Webpack別名的問題

    解決Idea、WebStorm下使用Vue cli腳手架項目無法使用Webpack別名的問題

    這篇文章主要介紹了解決Idea、WebStorm下使用Vue cli腳手架項目無法使用Webpack別名的問題,需要的朋友可以參考下
    2019-10-10
  • vue中的計算屬性傳參

    vue中的計算屬性傳參

    這篇文章主要介紹了vue中的計算屬性傳參,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 深入詳解Vue3中的Mock數(shù)據(jù)模擬

    深入詳解Vue3中的Mock數(shù)據(jù)模擬

    這篇文章主要為大家介紹了深入Vue3中的Mock數(shù)據(jù)模擬實現(xiàn)細(xì)節(jié)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05

最新評論