vue監(jiān)聽路由變化時(shí)watch方法會(huì)執(zhí)行多次的原因及解決
本人前端菜鳥一名,一直致力于不間斷的生產(chǎn)管理后臺(tái)的bug,并以此自勉自勵(lì)。近幾天接到一個(gè)需求,網(wǎng)上也搜了很多例子,但是沒有從根本上解決。在這里記錄一下我自己的解決的過程,這也是第一次在掘金發(fā)言,求輕虐。
需求描述:
有A、B兩個(gè)頁面,需要將A頁面的orderId用路由傳參的方式傳入到B頁面執(zhí)行數(shù)據(jù)關(guān)聯(lián)查詢,然后顯示在B頁面
需求解析:
如果是你,你拿到這個(gè)需求,應(yīng)該很容易想到在B頁面對(duì)路由變化做watch,然后獲取參數(shù)執(zhí)行查詢數(shù)據(jù)的方法完事。
解決需求
A頁面中:
const route = {
name: 'BpageName',
params: { orderId: this.tableData[index].id },
meta: {
title: 'B頁面'
}
}
this.$router.push(route)
push一個(gè)路由重新打開B頁面
然后B頁面中接受路由傳參:
@Watch('$route.params.packageId')
routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復(fù)制參數(shù)
if (newParams) {
this.getList(newParams)
}
}
看起來是不是很簡單?
但是問題來了,因?yàn)锽頁面做了keep-alive頁面緩存,第一次路由切換的時(shí)候routeParamsChanged方法只執(zhí)行一次,達(dá)到了預(yù)期效果。但是,如果關(guān)閉B頁面或者不關(guān)閉B頁面的情況下再從A頁面跳轉(zhuǎn)到B頁面的情況下就會(huì)觸發(fā)兩次或多次routeParamsChanged方法。
查了很多資料,vue項(xiàng)目watch內(nèi)的函數(shù)重復(fù)觸發(fā)問題 這里有解釋造成這種情況的原因。
解決方法1: 判斷fullPath是不是A頁面
if (this.$route.fullPath === 'A頁面路由路徑') {
// do something
}
懷著激動(dòng)的心情去試了試
@Watch('$route')
routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復(fù)制參數(shù)
if (newParams === '/Apage') {
this.getList(newParams)
}
}
結(jié)果還是不行,routeParamsChanged方法還是會(huì)執(zhí)行兩次或多次。 解決方法2 添加一個(gè)flag參數(shù)來判斷頁面是否是active狀態(tài),使用keep-alive緩存的組件只會(huì)觸發(fā)activated和deactivated事件,所以就在這兩個(gè)事件觸發(fā)時(shí)把flag置為true和false,只有在flag為true的時(shí)候才執(zhí)行g(shù)etList()。
private activatedFlag: boolean = false
activated () {
this.activatedFlag = true;
}
deactivated () {
this.activatedFlag = false;
}
@Watch('$route')
routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復(fù)制參數(shù)
if (newParams && this.activatedFlag) {
this.getList(newParams)
}
}
這回改解決了吧?結(jié)果還是不行,routeParamsChanged方法還是會(huì)執(zhí)行兩次或多次。 崩潰ing.........
問題解決
借鑒了上面的解決方法2,最終在activated ()生命周期鉤子函數(shù)中取實(shí)現(xiàn)獲取參數(shù)且調(diào)用獲取數(shù)據(jù)的方法即可,都不用去監(jiān)聽路由的變化,只要獲取了this.$route.params.orderId就去獲取數(shù)據(jù)。
private activatedFlag: boolean = false
activated () {
this.activatedFlag = true
if (this.$route.params.orderId && this.activatedFlag) {
this.getList(this.$route.params.orderId)
}
}
deactivated () {
this.activatedFlag = false;
}
大功告成,終于解決了。大佬們求輕吐槽代碼,有更好的意見或建議,歡迎評(píng)論留言指導(dǎo)。
以上就是vue監(jiān)聽路由變化時(shí)watch方法會(huì)執(zhí)行多次的原因及解決的詳細(xì)內(nèi)容,更多關(guān)于vue watch方法會(huì)執(zhí)行多次的原因及解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue項(xiàng)目在env文件中設(shè)置的變量無效問題及解決
這篇文章主要介紹了vue項(xiàng)目在env文件中設(shè)置的變量無效問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue項(xiàng)目移動(dòng)端實(shí)現(xiàn)ip輸入框問題
這篇文章主要介紹了vue項(xiàng)目移動(dòng)端實(shí)現(xiàn)ip輸入框問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03
使用WebStorm用Debug模式調(diào)試Vue等前端項(xiàng)目的步驟
WebStorm提供了更簡單的前端調(diào)試方法,記錄一下WebStorm調(diào)試步驟啟動(dòng)前端項(xiàng)目,這篇文章主要介紹了使用WebStorm用Debug模式調(diào)試Vue等前端項(xiàng)目的步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-11-11
vue項(xiàng)目使用modbus實(shí)現(xiàn)串口通訊的示例代碼
本文主要介紹了vue項(xiàng)目使用modbus實(shí)現(xiàn)串口通訊的示例代碼,可以實(shí)現(xiàn)與Modbus設(shè)備的數(shù)據(jù)交互,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-02-02
vue實(shí)現(xiàn)簡單實(shí)時(shí)匯率計(jì)算功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡單實(shí)時(shí)匯率計(jì)算功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
詳解Vue的數(shù)據(jù)及事件綁定和filter過濾器
這篇文章主要為大家介紹了Vue的數(shù)據(jù)及事件綁定和filter過濾器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01
vue頭部導(dǎo)航動(dòng)態(tài)點(diǎn)擊處理方法
這篇文章主要介紹了vue頭部導(dǎo)航動(dòng)態(tài)點(diǎn)擊處理方法,文中通過一段示例代碼給大家介紹了vue實(shí)現(xiàn)動(dòng)態(tài)頭部的方法,需要的朋友可以參考下2018-11-11

