淺談針對(duì)Vue相同路由不同參數(shù)的刷新問(wèn)題
在使用vue和vue-router開(kāi)發(fā)spa應(yīng)用時(shí),我們會(huì)遇到這樣一種問(wèn)題。
當(dāng)頁(yè)面跳轉(zhuǎn)時(shí),組件本身并沒(méi)有發(fā)生改變:
// 路由映射關(guān)系'/form/:type'
// 當(dāng)前頁(yè)面路由/form/shop1
this.$router.push({ name: 'form', params: { type: 'shop2' })
這時(shí)我們進(jìn)行路由跳轉(zhuǎn)后會(huì)發(fā)現(xiàn)組件并沒(méi)有刷新,在前一個(gè)路由組件的數(shù)據(jù)都保留了下來(lái),這并不是我們想要的效果。
對(duì)于簡(jiǎn)單的數(shù)據(jù)更新,我們可以直接監(jiān)聽(tīng)路由參數(shù)并重新獲取路由的初始化數(shù)據(jù)即可,
但是對(duì)于有很多子組件需要初始化或者reset的情況,我們還是有必要重新執(zhí)行組件的生命周期。
針對(duì)這種情況可以使用三種方式解決:
1.為相同路由頁(yè)面的跳轉(zhuǎn)進(jìn)行中間路由替換,在router上注冊(cè)beforeEach全局守衛(wèi)進(jìn)行攔截,跳轉(zhuǎn)到一個(gè)中間路由(例如empty),再?gòu)闹虚g過(guò)渡路由跳轉(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()
}
})
// 中間過(guò)渡路由
let toPath = this.$route.query.toPath
if (this.toPath) {
this.$router.push({ path: this.toPath })
}
2.使用v-if重新渲染當(dāng)前頁(yè)面組件
// 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值來(lái)進(jìn)行強(qiáng)制刷新
vue文檔說(shuō)明了當(dāng)你需要
- 完整地觸發(fā)組件的生命周期鉤子
- 觸發(fā)過(guò)渡
的時(shí)候可以利用更新組件綁定的key值來(lái)完成更詳細(xì)的說(shuō)明
這樣直接為組件綁定與路由參數(shù)關(guān)聯(lián)的值即可
<MyComponent :key="routeParams" />
綜合來(lái)看,第三種方式最簡(jiǎn)單,推薦使用。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue內(nèi)嵌iframe跨域通信的實(shí)例代碼
這篇文章主要介紹了vue內(nèi)嵌iframe跨域通信,主要介紹了Vue組件中如何引入iframe,vue如何獲取iframe對(duì)象以及iframe內(nèi)的window對(duì)象,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì)需要的朋友可以參考下2022-11-11
ElementUI?復(fù)雜頂部和左側(cè)導(dǎo)航欄實(shí)現(xiàn)示例
本文主要介紹了ElementUI?復(fù)雜頂部和左側(cè)導(dǎo)航欄實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
Vue Computed中g(shù)et和set的用法及Computed與watch的區(qū)別
這篇文章主要介紹了Vue Computed中g(shù)et和set的用法及Computed與watch的區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
vue實(shí)現(xiàn)全屏滾動(dòng)效果(非fullpage.js)
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)全屏滾動(dòng)效果,非fullpage.js,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
前端vue如何根據(jù)菜單自動(dòng)生成路由(動(dòng)態(tài)配置前端路由)
估計(jì)有不少人遇過(guò)這樣的需求:根據(jù)后臺(tái)數(shù)據(jù)動(dòng)態(tài)添加路由和菜單,這篇文章主要給大家介紹了關(guān)于前端vue如何根據(jù)菜單自動(dòng)生成路由的相關(guān)資料,需要的朋友可以參考下2024-04-04
Vue在原窗口與新窗口打開(kāi)外部鏈接的實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue如何在原窗口與新窗口打開(kāi)外部鏈接,文中給大家提到了vue跳轉(zhuǎn)外部鏈接的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
通過(guò)一個(gè)簡(jiǎn)單的例子學(xué)會(huì)vuex與模塊化
這篇文章主要給大家介紹了關(guān)于如何通過(guò)一個(gè)簡(jiǎn)單的例子學(xué)會(huì)vuex與模塊化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11

