欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談針對(duì)Vue相同路由不同參數(shù)的刷新問題

 更新時(shí)間:2018年09月29日 14:19:36   作者:Fiend  
這篇文章主要介紹了淺談針對(duì)Vue相同路由不同參數(shù)的刷新問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

在使用vue和vue-router開發(fā)spa應(yīng)用時(shí),我們會(huì)遇到這樣一種問題。

當(dāng)頁面跳轉(zhuǎn)時(shí),組件本身并沒有發(fā)生改變:

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

這時(shí)我們進(jìn)行路由跳轉(zhuǎn)后會(huì)發(fā)現(xiàn)組件并沒有刷新,在前一個(gè)路由組件的數(shù)據(jù)都保留了下來,這并不是我們想要的效果。

對(duì)于簡單的數(shù)據(jù)更新,我們可以直接監(jiān)聽路由參數(shù)并重新獲取路由的初始化數(shù)據(jù)即可,
但是對(duì)于有很多子組件需要初始化或者reset的情況,我們還是有必要重新執(zhí)行組件的生命周期。

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

1.為相同路由頁面的跳轉(zhuǎn)進(jìn)行中間路由替換,在router上注冊(cè)beforeEach全局守衛(wèi)進(jìn)行攔截,跳轉(zhuǎn)到一個(gè)中間路由(例如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))
  } 
 }
}

這樣把方法注冊(cè)到跟組件上,對(duì)于想刷新的組件直接調(diào)用reload方法即可。

3.使用vue文檔組件綁定的key值來進(jìn)行強(qiáng)制刷新

vue文檔說明了當(dāng)你需要

  • 完整地觸發(fā)組件的生命周期鉤子
  • 觸發(fā)過渡

的時(shí)候可以利用更新組件綁定的key值來完成更詳細(xì)的說明

這樣直接為組件綁定與路由參數(shù)關(guān)聯(lián)的值即可

<MyComponent :key="routeParams" />

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

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論