一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - vue項目watch內的函數重復觸發問題的解決

vue項目watch內的函數重復觸發問題的解決

2022-02-25 16:43liyang vue.js

這篇文章主要介紹了vue項目watch內的函數重復觸發問題的兩種解決方案,幫助大家更好的理解和學習使用vue,感興趣的朋友可以了解下

問題描述:

有兩個頁面A和B,每個頁面里都有一個getList()方法。這個兩個方法都需要傳一個相同的參數C,參數C的選擇過程又比較麻煩。為了避免在切換A、B兩個界面重復選擇參數C的問題,我將參數C存入vuex中,然后在兩個頁面里都使用watch監聽參數C來執行getList()方法。然后發現一個問題,從A頁面進入B頁面后,在B頁面重新選擇參數C,A頁面的getList()方法竟然也會被執行,反之亦然,從B頁面到A頁面后,在A頁面改變參數C也會執行B頁面的getList()方法。

后來發現是使用了因為使用了keep-alive所致,keep-alive會將Vue實例始終保持在內存中,因此該Vue實例始終存續,相應的watchers始終生效,查找相關資料后,發現許多人也遇到了這個問題,最后找到以下兩種解決方案:

解決方法1

通過router路徑來判斷是否執行getList()

?
1
2
3
4
5
6
7
watch: {
        someValue(newValue, oldValue) {
            if (this.$route.fullPath === 'A頁面路由路徑') {
                // do something
            }
        }
    }

解決方法2

添加一個flag參數來判斷頁面是否是active狀態,使用keep-alive緩存的組件只會觸發activateddeactivated事件,所以就在這兩個事件觸發時把flag置為true和false,只有在flag為true的時候才執行getList()

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
{
  data () {
    return {
      activatedFlag: false
    };
  },
  watch: {
    'someValue'(val) {
      if(val && this.activatedFlag) {
        this.getlist();
      }
    }
  },
  activated () {
    this.activatedFlag = true;
  },
  deactivated () {
    this.activatedFlag = false;
  }
}

如果頁面比較多,而且各頁面里的函數名稱不一致的話,可以把上面代碼的watch部分去掉寫成一個mixin,在需要的頁面引入即可

?
1
2
3
4
5
6
7
8
9
10
11
12
13
import activeFlag from "@/mixin/activeFlag";
 
export default {
  mixins: [activeFlag],
  watch: {
      'someValue'(val) {
        if(val && this.activatedFlag) {
          this.getlistA();
          this.getlistB();
        }
      }
    },
}

以上就是vue項目watch內的函數重復觸發問題的兩種解決方案的詳細內容,更多關于vue watch函數重復觸發解決的資料請關注服務器之家其它相關文章!

原文鏈接:https://liyangzone.com/

延伸 · 閱讀

精彩推薦
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
  • vue.jsVue2.x-使用防抖以及節流的示例

    Vue2.x-使用防抖以及節流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
主站蜘蛛池模板: 精精国产www视频在线观看免费 | 久久中文骚妇内射 | 扒开女人下面 | a级aaaaaaaa毛片| 免费看欧美一级特黄a大片一 | 日本三级斤 | 极品ts赵恩静和直男激战啪啪 | 精品无码人妻一区二区免费AV | 欧美另类bbbxxxxx另类 | 草莓视频在线观看免费 | 四虎国产免费 | 免费看一级大片 | 亚州日韩精品AV片无码中文 | 99精品久久精品一区二区小说 | 9420高清视频在线观看网百度 | 日韩一区二区三区免费 | 国产成人精品一区二三区 | 无码专区aaaaaa免费视频 | 91短视频在线免费观看 | 亚洲精品97福利在线 | 亚洲日本免费 | 吃瓜视频在线观看 | 91寡妇天天综合久久影院 | 性xx色3d动画xx无尽 | 操好爽| 天天做天天爽天天谢 | 女仆色在线观看 | 亚洲精品中文字幕第一区 | 成人免费影院 | 美女毛片老太婆bbb80岁 | 国产一级精品高清一级毛片 | 日本人成大片在线 | 日本网| 亚瑟天堂久久一区二区影院 | 包臀裙女教师波多野结衣 | 国产伦精品一区二区三区免费观看 | 好 舒服 好 粗 好硬 好爽 | 免费观看www视频 | 日韩在线免费 | 91麻豆精品 | 欧美亚洲免费 |