針對Vue相同路由不同引數的重新整理問題
阿新 • • 發佈:2018-12-17
在使用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" />
綜合來看,第三種方式最簡單,推薦使用。