国产探花免费观看_亚洲丰满少妇自慰呻吟_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" />

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

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

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

圖片精選

主站蜘蛛池模板: 措美县| 靖西县| 湘潭市| 红桥区| 高唐县| 巧家县| 武川县| 阳朔县| 崇礼县| 隆昌县| 阿尔山市| 大足县| 宜宾市| 呈贡县| 宁乡县| 寿宁县| 无为县| 六枝特区| 大厂| 吴桥县| 崇阳县| 抚顺市| 定西市| 庐江县| 布尔津县| 溆浦县| 五原县| 临江市| 克拉玛依市| 阿巴嘎旗| 南乐县| 陆河县| 花莲市| 镇巴县| 时尚| 苍溪县| 安福县| 万荣县| 河池市| 彭阳县| 宜都市|