這篇文章給大家分享的是有關如何解決Vue相同路由不同參數(shù)的刷新問題的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)建站是一家專注于網(wǎng)站設計、成都做網(wǎng)站與策劃設計,夷陵網(wǎng)站建設哪家好?創(chuàng)新互聯(lián)建站做網(wǎng)站,專注于網(wǎng)站建設10多年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:夷陵等地區(qū)。夷陵做網(wǎng)站價格咨詢:18982081108在使用vue和vue-router開發(fā)spa應用時,我們會遇到這樣一種問題。
當頁面跳轉時,組件本身并沒有發(fā)生改變:
// 路由映射關系'/form/:type' // 當前頁面路由/form/shop1 this.$router.push({ name: 'form', params: { type: 'shop2' })
這時我們進行路由跳轉后會發(fā)現(xiàn)組件并沒有刷新,在前一個路由組件的數(shù)據(jù)都保留了下來,這并不是我們想要的效果。
對于簡單的數(shù)據(jù)更新,我們可以直接監(jiān)聽路由參數(shù)并重新獲取路由的初始化數(shù)據(jù)即可,
但是對于有很多子組件需要初始化或者reset的情況,我們還是有必要重新執(zhí)行組件的生命周期。
針對這種情況可以使用三種方式解決:
1.為相同路由頁面的跳轉進行中間路由替換,在router上注冊beforeEach全局守衛(wèi)進行攔截,跳轉到一個中間路由(例如empty),再從中間過渡路由跳轉至要去的路由。
// 全局導航守衛(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重新渲染當前頁面組件
// html部分// script部分 export default { data () { return { isRouterAlive: true } }, methods: { reload () { this.showRouterView = false this.$nextTick(() => (this.showRouterView = true)) } } }
這樣把方法注冊到跟組件上,對于想刷新的組件直接調(diào)用reload方法即可。
3.使用vue文檔組件綁定的key值來進行強制刷新
vue文檔說明了當你需要
完整地觸發(fā)組件的生命周期鉤子
觸發(fā)過渡
的時候可以利用更新組件綁定的key值來完成更詳細的說明
這樣直接為組件綁定與路由參數(shù)關聯(lián)的值即可
綜合來看,第三種方式最簡單,推薦使用。
感謝各位的閱讀!關于“如何解決Vue相同路由不同參數(shù)的刷新問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。