亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于Vuex無法觀察到值變化的解決方法

 更新時間:2018年03月01日 10:15:46   作者:蟻方陣  
下面小編就為大家分享一篇基于Vuex無法觀察到值變化的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在跨越主路由視圖時,由于Vuex的狀態(tài)值一直存儲在內(nèi)存中,所以在組件視圖重新載入時,可能會出現(xiàn)組件無法檢測到狀態(tài)值的變化,從而導致業(yè)務邏輯出現(xiàn)錯誤。

假定通用頭部組件有一個全局任務狀態(tài)值,其他的組件都要根據(jù)此任務值進行更新,更可能出現(xiàn)的情況是,任務狀態(tài)值是異步加載完成的,于是需要如此編寫業(yè)務邏輯:

computed : {
 task () {
  return this.$store.state.task
 } 
},
watch : {
 task : {
   deep: true,
   handler (val) {
    // 由于是異步載入,所以只能在狀態(tài)值的變化時執(zhí)行渲染操作
    // 絕不可在mounted中執(zhí)行render方法
    this.render(val)
   }
 } 
}

但是,由于上面的原因,第一次載入視圖時,因為Vuex的狀態(tài)值還沒有存儲在內(nèi)存中,所以渲染正常。發(fā)生了視圖切換后,雖然也重新載入了任務狀態(tài)值,但由于task并沒有發(fā)生變化,所以render方法不會被調(diào)用,于是組件無法完成渲染過程。

解決的辦法很簡單,強行觸發(fā)task值發(fā)生改變,方法是定義一個時間戳,如果覺得在時間戳的粒度仍然太粗,還可以組合使用隨機數(shù),如下:

watch: {
 taskId : {
   handler (val) {
    // 從v-model獲取到的新值
    let taskId = this.taskId
    // 提交新值變化
    this.$store.commit(TASK_ID, 
    {
     id : taskId,
     // 添加時間戳
     time : Date.now().valueOf(),
     // 添加隨機數(shù)
     random : Math.random()
    })
   }
 }
}

經(jīng)過上面的處理,只要發(fā)生taskId的賦值現(xiàn)象,那么一定會觸發(fā)Vuex的狀態(tài)變化,所以每次組件載入時或taskId的值發(fā)生變化時,render方法就一定會被執(zhí)行。

結(jié)論

為了滿足Vuex的值傳遞要求,尤其是需要強行刷新Vuex的緩存時,添加時間戳與隨機數(shù)不失為一種好的解決方案。

以上這篇基于Vuex無法觀察到值變化的解決方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3?element-plus?實現(xiàn)表格數(shù)據(jù)更改功能詳細步驟

    vue3?element-plus?實現(xiàn)表格數(shù)據(jù)更改功能詳細步驟

    這篇文章主要介紹了vue3 element-plus實現(xiàn)表格數(shù)據(jù)更改功能,本文分步驟結(jié)合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • vue實現(xiàn)PC端錄音功能的實例代碼

    vue實現(xiàn)PC端錄音功能的實例代碼

    這篇文章主要介紹了vue實現(xiàn)PC端錄音功能的實例代碼,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • 在小程序/mpvue中使用flyio發(fā)起網(wǎng)絡請求的方法

    在小程序/mpvue中使用flyio發(fā)起網(wǎng)絡請求的方法

    這篇文章主要介紹了在小程序/mpvue中使用flyio發(fā)起網(wǎng)絡請求的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 解決vue中axios設置超時(超過5分鐘)沒反應的問題

    解決vue中axios設置超時(超過5分鐘)沒反應的問題

    這篇文章主要介紹了解決vue中axios設置超時(超過5分鐘)沒反應的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • vue 項目中使用websocket的正確姿勢

    vue 項目中使用websocket的正確姿勢

    這篇文章主要介紹了vue 項目中使用websocket的實例代碼,通過實例代碼給大家介紹了在utils下新建websocket.js文件的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • vue攔截器及請求封裝代碼

    vue攔截器及請求封裝代碼

    這篇文章主要介紹了vue攔截器及請求封裝代碼,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue3使用v-html實現(xiàn)文本關(guān)鍵詞變色處理

    Vue3使用v-html實現(xiàn)文本關(guān)鍵詞變色處理

    遍歷文本內(nèi)容,找到關(guān)鍵詞,并使用某種方法更改其字體樣式,經(jīng)過搜尋資料決定采用v-html實現(xiàn),但是v-html本身并不安全,有安全性風險且影響性能,所以謹慎使用,本文給大家介紹了Vue3使用v-html實現(xiàn)文本關(guān)鍵詞變色處理,需要的朋友可以參考下
    2024-06-06
  • Vue+Element實現(xiàn)封裝抽屜彈框

    Vue+Element實現(xiàn)封裝抽屜彈框

    這篇文章主要為大家詳細介紹了如何利用Vue和Element實現(xiàn)簡單的抽屜彈框效果,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-06-06
  • vue項目中mock.js的使用及基本用法

    vue項目中mock.js的使用及基本用法

    mockjs是用來模擬產(chǎn)生一些虛擬的數(shù)據(jù),可以讓前端在后端接口還沒有開發(fā)出來時獨立開發(fā)。這篇文章主要介紹了vue項目中mock.js的使用,需要的朋友可以參考下
    2019-05-05
  • Vue3中使用富文本編輯器的方法詳解

    Vue3中使用富文本編輯器的方法詳解

    這篇文章主要為大家詳細介紹了如何在Vue3中使用富文本編輯器,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以參考一下
    2024-01-01

最新評論