詳解使用Vue Router導航鉤子與Vuex來實現(xiàn)后退狀態(tài)保存
不好意思,標題比較啰嗦,因為這次的流水賬確實屬于一個比較細節(jié)的小東西,下面詳細講:
1需求
最近在使用electron-vue 開發(fā)一個跨平臺的桌面端軟件,剛上手寫了幾個頁面,遇到一個問題:桌面端軟件通常會有導航需求,類似下圖

導航按鈕
點擊返回按鈕,返回上一頁,并且顯示上頁內(nèi)容。其實不止App,即使普通的網(wǎng)頁中也會有此類需求,尤其是使用vue寫SPA時。
項目中的導航幾乎都是采用router.push({name: 'xxx', params: {xxx:123...}})這種方式。這種方式導致的一個直接問題是:當點擊后退按鈕(調(diào)用 router.go(-1))時,history中只保存了URL而丟失了params對象,進而導致依賴params的頁面渲染異常。
2 解決
其實思路很簡單,既然是在后退操作中丟失了params,那么我們自然會想到:如何保存一下params!沒錯,就是這么粗暴,你既然要丟,我就把你保存一下!
怎么存: 其實想都不用想這是一個跨組件通信問題拉,所以很自然的,用Vuex保存是最合乎常理的咯!
什么時候存:第一反應,調(diào)用 router.push({name: 'xxx', params: {xxx:123...}})時保存,然后如果導航回到這個URL,如果沒有params,嘗試從vuex store里取。似乎沒錯,就是麻煩了點兒!!別慌,咱們有導航鉤子 router.beforeEach((to, from, next) => { // ... }) 啊!
正如其名,vue-router 提供的導航鉤子主要用來攔截導航,讓它完成跳轉(zhuǎn)或取消。
說到這兒,你應該完全明白我的解決思路了,那下面廢話就不多說了,上代碼:
/*
Vuex store 定義存儲對象RouterParams
*/
//...
const state = {
//定義一個存儲map,key:導航name,value:導航params
paramMap: {}
}
const mutations = {
REFRESHPARAM (state, paramKV) {
//mutation,應該能看懂做的操作吧?
Vue.set(state.paramMap, paramKV.key, paramKV.value)
}
}
//...
/*
router中設(shè)置一個全局導航鉤子
*/
const router = new VueRouter({ ... }) //router
router.beforeEach((to, from, next) => {
// 只有在找不到params時才"出此下策"
if (Object.keys(to.params).length === 0) {
// 從store中取出付給params,此處注意路徑未必完全吻合,以你的為準
Object.assign(to.params, store.state.RouterParams.paramMap[to.name] || {})
}
// 存儲一下params備用
store.commit('REFRESHPARAM', {key: to.name, value: to.params})
next() // 千萬不要忘了,否則導航會被“掐死”在這兒。:-D
})
//...
很簡單吧!總共沒有幾行代碼 O(∩_∩)O~
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用vue-router與v-if實現(xiàn)tab切換遇到的問題及解決方法
這篇文章主要介紹了vue-router與v-if實現(xiàn)tab切換的思考,需要的朋友可以參考下2018-09-09
Vue循環(huán)組件加validate多表單驗證的實例
今天小編就為大家分享一篇Vue循環(huán)組件加validate多表單驗證的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
關(guān)于vue打包時的publicPath就是打包后靜態(tài)資源的路徑問題
這篇文章主要介紹了vue打包時的publicPath,就是打包后靜態(tài)資源的路徑,本文通過三種情況分析給大家詳細介紹,需要的朋友可以參考下2022-07-07
Vue首屏加載過慢出現(xiàn)白屏的6種優(yōu)化方案匯總
vue項目打包上線后,首次打開會發(fā)現(xiàn)加載很慢,出現(xiàn)白屏的問題,下面這篇文章主要給大家介紹了關(guān)于Vue首屏加載過慢出現(xiàn)白屏的6種優(yōu)化方案,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02
vue3中ts語法使用element plus分頁組件警告錯誤問題
這篇文章主要介紹了vue3中ts語法使用element plus分頁組件警告錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
vue-cli3自動消除console.log()的調(diào)試信息方式
這篇文章主要介紹了vue-cli3自動消除console.log()的調(diào)試信息方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue中如何給el-table-column添加指定列的點擊事件
elementui中提供了點擊行處理事件,下面這篇文章主要給大家介紹了關(guān)于vue中如何給el-table-column添加指定列的點擊事件,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2022-11-11
Vue項目中使用jsonp抓取跨域數(shù)據(jù)的方法
這篇文章主要介紹了Vue項目中使用jsonp抓取跨域數(shù)據(jù)的方法,本文通過實例代碼講解的非常詳細,需要的朋友可以參考下2019-11-11
vue項目使用高德地圖時報錯:AMap?is?not?defined解決辦法
這篇文章主要給大家介紹了關(guān)于vue項目使用高德地圖時報錯:AMap?is?not?defined的解決辦法,"AMap is not defined"是一個錯誤提示,意思是在代碼中沒有找到定義的AMap,需要的朋友可以參考下2023-12-12

