国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

vue監(jiān)聽路由變化時watch方法會執(zhí)行多次的原因及解決

瀏覽:4日期:2022-09-30 17:52:19

本人前端菜鳥一名,一直致力于不間斷的生產管理后臺的bug,并以此自勉自勵。近幾天接到一個需求,網上也搜了很多例子,但是沒有從根本上解決。在這里記錄一下我自己的解決的過程,這也是第一次在掘金發(fā)言,求輕虐。

需求描述:

有A、B兩個頁面,需要將A頁面的orderId用路由傳參的方式傳入到B頁面執(zhí)行數(shù)據(jù)關聯(lián)查詢,然后顯示在B頁面

需求解析:

如果是你,你拿到這個需求,應該很容易想到在B頁面對路由變化做watch,然后獲取參數(shù)執(zhí)行查詢數(shù)據(jù)的方法完事。

解決需求

A頁面中:

const route = {name: ’BpageName’,params: { orderId: this.tableData[index].id },meta: { title: ’B頁面’} }this.$router.push(route)

push一個路由重新打開B頁面

然后B頁面中接受路由傳參:

@Watch(’$route.params.packageId’)routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復制參數(shù) if (newParams) { this.getList(newParams) }}

看起來是不是很簡單?

但是問題來了,因為B頁面做了keep-alive頁面緩存,第一次路由切換的時候routeParamsChanged方法只執(zhí)行一次,達到了預期效果。但是,如果關閉B頁面或者不關閉B頁面的情況下再從A頁面跳轉到B頁面的情況下就會觸發(fā)兩次或多次routeParamsChanged方法。查了很多資料,vue項目watch內的函數(shù)重復觸發(fā)問題 這里有解釋造成這種情況的原因。

解決方法1: 判斷fullPath是不是A頁面

if (this.$route.fullPath === ’A頁面路由路徑’) { // do something}

懷著激動的心情去試了試

@Watch(’$route’)routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復制參數(shù) if (newParams === ’/Apage’) { this.getList(newParams) }}

結果還是不行,routeParamsChanged方法還是會執(zhí)行兩次或多次。 解決方法2 添加一個flag參數(shù)來判斷頁面是否是active狀態(tài),使用keep-alive緩存的組件只會觸發(fā)activated和deactivated事件,所以就在這兩個事件觸發(fā)時把flag置為true和false,只有在flag為true的時候才執(zhí)行getList()。

private activatedFlag: boolean = falseactivated () { this.activatedFlag = true;}deactivated () { this.activatedFlag = false;}@Watch(’$route’)routeParamsChanged(newParams: any, oldParams: any) :void { // 通過監(jiān)聽傳參的變化來重新復制參數(shù) if (newParams && this.activatedFlag) { this.getList(newParams) }}

這回改解決了吧?結果還是不行,routeParamsChanged方法還是會執(zhí)行兩次或多次。 崩潰ing.........

問題解決

借鑒了上面的解決方法2,最終在activated ()生命周期鉤子函數(shù)中取實現(xiàn)獲取參數(shù)且調用獲取數(shù)據(jù)的方法即可,都不用去監(jiān)聽路由的變化,只要獲取了this.$route.params.orderId就去獲取數(shù)據(jù)。

private activatedFlag: boolean = falseactivated () { this.activatedFlag = true if (this.$route.params.orderId && this.activatedFlag) { this.getList(this.$route.params.orderId) }}deactivated () { this.activatedFlag = false;}

大功告成,終于解決了。大佬們求輕吐槽代碼,有更好的意見或建議,歡迎評論留言指導。

以上就是vue監(jiān)聽路由變化時watch方法會執(zhí)行多次的原因及解決的詳細內容,更多關于vue watch方法會執(zhí)行多次的原因及解決的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 欧美aaaaaabbbbb | 国产男人天堂 | 国产欧美日韩图片一区二区 | 亚洲国产第一区二区香蕉日日 | 成人一级大片 | 国产在线综合视频 | 国产欧美一区二区三区视频在线观看 | 日日狠狠久久偷偷四色综合免费 | 亚洲免费视频一区二区三区 | 手机看片久久国产免费不卡 | 92精品国产成人观看免费 | 国产成人精品免费视频大全可播放的 | 国产在线视频h | 亚洲成人一区在线 | 欧美f | 日本三级香港三级三级人!妇久 | 成年人免费黄色 | 一级一片免费看 | 国内精品美女写真视频 | 91热久久 | 嫩草影院ncyy在线观看 | 中日韩精品视频在线观看 | 一级特黄特色的免费大片视频 | 国产成人亚洲综合网站不卡 | 毛片网站在线播放 | 私人毛片免费高清影视院丶 | 欧美成人伊人十综合色 | 欧美另类视频一区二区三区 | 亚洲三级网 | 成人性动漫高清免费观看网址 | 成人性视频在线三级 | 国产美女精品视频 | 国产欧美一区二区三区在线看 | 一级淫片免费视频 | 亚洲最大成人 | 国产tv在线观看 | 中文字幕有码在线 | 韩国毛片在线 | 国产肥老妇视频一 | 美女黄频网站 | 欧美性妇 |