91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決Vue相同路由不同參數的刷新問題

發布時間:2021-09-08 14:54:18 來源:億速云 閱讀:278 作者:小新 欄目:web開發

這篇文章給大家分享的是有關如何解決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" />

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

感謝各位的閱讀!關于“如何解決Vue相同路由不同參數的刷新問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

陆河县| 西安市| 靖州| 宁远县| 浦城县| 永嘉县| 嵊州市| 青海省| 合川市| 罗定市| 万年县| 日喀则市| 汶川县| 温州市| 远安县| 彭州市| 江陵县| 芦山县| 仁寿县| 宜君县| 德格县| 醴陵市| 荥经县| 江门市| 灯塔市| 杭锦后旗| 建昌县| 库尔勒市| 景洪市| 大渡口区| 扬州市| 买车| 原阳县| 湾仔区| 马山县| 乳源| 措美县| 永顺县| 环江| 诸城市| 顺平县|