欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2021年04月09日 10:43:14   作者:๘࿆꧁༺༼蠟筆小舊༽  
這篇文章主要介紹了vue監(jiān)聽路由變化時watch方法會執(zhí)行多次的原因及解決,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下

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

需求描述:

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

需求解析:

如果是你,你拿到這個需求,應(yīng)該很容易想到在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)聽傳參的變化來重新復(fù)制參數(shù)
    if (newParams) {
      this.getList(newParams)
    }
}

看起來是不是很簡單?

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

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

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

懷著激動的心情去試了試

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

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

問題解決

借鑒了上面的解決方法2,最終在activated ()生命周期鉤子函數(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;
}

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

以上就是vue監(jiān)聽路由變化時watch方法會執(zhí)行多次的原因及解決的詳細(xì)內(nèi)容,更多關(guān)于vue watch方法會執(zhí)行多次的原因及解決的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue控制滾動條滑到某個位置的方法實例

    vue控制滾動條滑到某個位置的方法實例

    當(dāng)容器有滾動條時,有時需要將滾動條滑到某個位置,下面這篇文章主要給大家介紹了關(guān)于vue控制滾動條滑到某個位置的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • vue3(optionApi)使用Element Plus庫沒有效果的解決方式

    vue3(optionApi)使用Element Plus庫沒有效果的解決方式

    這篇文章主要介紹了vue3(optionApi)使用Element Plus庫沒有效果的解決方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 關(guān)于el-table-column的formatter的使用及說明

    關(guān)于el-table-column的formatter的使用及說明

    這篇文章主要介紹了關(guān)于el-table-column的formatter的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue項目啟動時無法識別es6的擴(kuò)展語法的解決

    vue項目啟動時無法識別es6的擴(kuò)展語法的解決

    啟動項目時遇到ES6的拓展運(yùn)算符報錯可以通過切換到淘寶鏡像,以及在項目根目錄下新增.babelrc和postcss.config.js文件來解決,這些操作有助于正確配置項目環(huán)境,從而避免報錯,并保證項目的順利運(yùn)行,希望這些經(jīng)驗?zāi)軌驇椭接龅较嗤瑔栴}的開發(fā)者
    2024-10-10
  • Vue學(xué)習(xí)之組件用法實例詳解

    Vue學(xué)習(xí)之組件用法實例詳解

    這篇文章主要介紹了Vue學(xué)習(xí)之組件用法,結(jié)合實例形式分析了vue.js組件的使用流程、模板、父子組件、插槽slot等相關(guān)原理與操作技巧,需要的朋友可以參考下
    2020-01-01
  • vue - vue.config.js中devServer配置方式

    vue - vue.config.js中devServer配置方式

    今天小編就為大家分享一篇vue - vue.config.js中devServer配置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue中watch清除過期副作用的案例詳解

    Vue中watch清除過期副作用的案例詳解

    在這里就不過多說watch的用法了,這篇文章主要通過案例帶大家了解一下如何清除過期的副作用。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2023-01-01
  • vue篇之事件總線EventBus使用示例詳解

    vue篇之事件總線EventBus使用示例詳解

    這篇文章主要為大家介紹了vue篇之事件總線EventBus使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue實現(xiàn)簡單的星級評分組件源碼

    vue實現(xiàn)簡單的星級評分組件源碼

    這篇文章主要介紹了vue星級評分組件源碼,代碼簡單易懂非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • 一文詳解怎么安裝離線vue環(huán)境

    一文詳解怎么安裝離線vue環(huán)境

    這篇文章主要給大家介紹了關(guān)于怎么安裝離線vue環(huán)境的相關(guān)資料,由于公司要求在內(nèi)網(wǎng)開發(fā)項目,而內(nèi)網(wǎng)不能連接外網(wǎng),因此只能離線安裝vue環(huán)境,需要的朋友可以參考下
    2023-12-12

最新評論