在使用vue和vue-router開發spa應用時,咱們會遇到這樣一種問題。html
當頁面跳轉時,組件自己並無發生改變:前端
// 路由映射關係'/form/:type' // 當前頁面路由/form/shop1 this.$router.push({ name: 'form', params: { type: 'shop2' })
這時咱們進行路由跳轉後會發現組件並無刷新,在前一個路由組件的數據都保留了下來,這並非咱們想要的效果。vue
對於簡單的數據更新,咱們能夠直接監聽路由參數並從新獲取路由的初始化數據便可, 可是對於有不少子組件須要初始化或者reset的狀況,咱們仍是有必要從新執行組件的生命週期。面試
針對這種狀況能夠使用三種方式解決:vue-router
1.爲相同路由頁面的跳轉進行中間路由替換,在router上註冊beforeEach全局守衛進行攔截,跳轉到一箇中間路由(例如empty),再從中間過渡路由跳轉至要去的路由。api
// 全局導航守衛 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)) } } }
對前端的技術,架構技術感興趣的同窗關注個人頭條號,並在後臺私信發送關鍵字:「前端」便可獲取免費的架構師學習資料this
這樣把方法註冊到跟組件上,對於想刷新的組件直接調用reload方法便可。spa
3.使用vue文檔組件綁定的key值來進行強制刷新
vue文檔說明了當你須要
的時候能夠利用更新組件綁定的key值來完成更詳細的說明
這樣直接爲組件綁定與路由參數關聯的值便可
MyComponent :key="routeParams" />
綜合來看,第三種方式最簡單,推薦使用。