淺談針對Vue相同路由不同參數(shù)的刷新問題
在使用vue和vue-router開發(fā)spa應(yīng)用時,我們會遇到這樣一種問題。
當(dāng)頁面跳轉(zhuǎn)時,組件本身并沒有發(fā)生改變:
// 路由映射關(guān)系'/form/:type' // 當(dāng)前頁面路由/form/shop1 this.$router.push({ name: 'form', params: { type: 'shop2' })
這時我們進行路由跳轉(zhuǎn)后會發(fā)現(xiàn)組件并沒有刷新,在前一個路由組件的數(shù)據(jù)都保留了下來,這并不是我們想要的效果。
對于簡單的數(shù)據(jù)更新,我們可以直接監(jiān)聽路由參數(shù)并重新獲取路由的初始化數(shù)據(jù)即可,
但是對于有很多子組件需要初始化或者reset的情況,我們還是有必要重新執(zhí)行組件的生命周期。
針對這種情況可以使用三種方式解決:
1.為相同路由頁面的跳轉(zhuǎn)進行中間路由替換,在router上注冊beforeEach全局守衛(wèi)進行攔截,跳轉(zhuǎn)到一個中間路由(例如empty),再從中間過渡路由跳轉(zhuǎn)至要去的路由。
// 全局導(dǎo)航守衛(wèi) router.beforeEach((to, from, next) => { if (to.name === from.name && to.params.type !== from.params.type) { next({ name: 'empty', query: { toPath: to.fullPath } }) } else { next() } }) // 中間過渡路由 let toPath = this.$route.query.toPath if (this.toPath) { this.$router.push({ path: this.toPath }) }
2.使用v-if重新渲染當(dāng)前頁面組件
// html部分 <div> <router-view v-if="showRouterView"/> </div> // script部分 export default { data () { return { isRouterAlive: true } }, methods: { reload () { this.showRouterView = false this.$nextTick(() => (this.showRouterView = true)) } } }
這樣把方法注冊到跟組件上,對于想刷新的組件直接調(diào)用reload方法即可。
3.使用vue文檔組件綁定的key值來進行強制刷新
vue文檔說明了當(dāng)你需要
- 完整地觸發(fā)組件的生命周期鉤子
- 觸發(fā)過渡
的時候可以利用更新組件綁定的key值來完成更詳細的說明
這樣直接為組件綁定與路由參數(shù)關(guān)聯(lián)的值即可
<MyComponent :key="routeParams" />
綜合來看,第三種方式最簡單,推薦使用。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
antd?vue中,如何在form表單中的自定義組件使用v-decorator
antd?vue中,在form表單中的自定義組件使用v-decorator問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04vue如何從后臺獲取數(shù)據(jù)生成動態(tài)菜單列表
這篇文章主要介紹了vue如何從后臺獲取數(shù)據(jù)生成動態(tài)菜單列表,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04vue?懸浮窗且?guī)ё詣游焦δ軐崿F(xiàn)demo
這篇文章主要為大家介紹了vue?懸浮窗且?guī)ё詣游焦δ軐崿F(xiàn)demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06Vue3發(fā)送post請求出現(xiàn)400?Bad?Request報錯的解決辦法
這篇文章主要給大家介紹了關(guān)于Vue3發(fā)送post請求出現(xiàn)400?Bad?Request報錯的解決辦法,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-02-02vue.js利用defineProperty實現(xiàn)數(shù)據(jù)的雙向綁定
本篇文章主要介紹了用Node.js當(dāng)作后臺、jQuery寫前臺AJAX代碼實現(xiàn)用戶登錄和注冊的功能的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04