国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:29:11
字體:
來源:轉載
供稿:網友

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

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

// 路由映射關系'/form/:type'// 當前頁面路由/form/shop1this.$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.toPathif (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" />

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 太仓市| 乌苏市| 宜章县| 铜川市| 柳河县| 富锦市| 秦皇岛市| 惠安县| 德清县| 绍兴市| 临沂市| 安阳县| 如皋市| 阿鲁科尔沁旗| 滕州市| 宁化县| 靖州| 昌平区| 巨野县| 拉孜县| 肃南| 渑池县| 长宁县| 扎赉特旗| 年辖:市辖区| 甘泉县| 安顺市| 通州市| 绥江县| 诸城市| 静乐县| 雷波县| 通江县| 安康市| 嘉禾县| 巩义市| 睢宁县| 台北市| 铁岭县| 五大连池市| 平利县|