淺談針對Vue相同路由不同參數的刷新問題

在使用vue和vue-router開發spa應用時,我們會遇到這樣一種問題。

當頁面跳轉時,組件本身並沒有發生改變:

// 路由映射關係'/form/:type'
// 當前頁面路由/form/shop1
this.$router.push({ name: 'form', params: { type: 'shop2' })

這時我們進行路由跳轉後會發現組件並沒有刷新,在前一個路由組件的數據都保留了下來,這並不是我們想要的效果。

對於簡單的數據更新,我們可以直接監聽路由參數並重新獲取路由的初始化數據即可,
但是對於有很多子組件需要初始化或者reset的情況,我們還是有必要重新執行組件的生命週期。

針對這種情況可以使用三種方式解決:

1.爲相同路由頁面的跳轉進行中間路由替換,在router上註冊beforeEach全局守衛進行攔截,跳轉到一箇中間路由(例如empty),再從中間過渡路由跳轉至要去的路由。

// 全局導航守衛
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重新渲染當前頁面組件

// 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))
  } 
 }
}

對前端的技術,架構技術感興趣的同學關注我的頭條號,並在後臺私信發送關鍵字:“前端”即可獲取免費的架構師學習資料

這樣把方法註冊到跟組件上,對於想刷新的組件直接調用reload方法即可。

3.使用vue文檔組件綁定的key值來進行強制刷新

vue文檔說明了當你需要

  • 完整地觸發組件的生命週期鉤子
  • 觸發過渡

的時候可以利用更新組件綁定的key值來完成更詳細的說明

這樣直接爲組件綁定與路由參數關聯的值即可

MyComponent :key="routeParams" />

綜合來看,第三種方式最簡單,推薦使用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章