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

關于vuex更新視圖引發(fā)的一些思考詳析

 更新時間:2022年06月15日 10:03:42   作者:朝著全棧加速前進  
我們在vuex中操作數(shù)據(jù)時遇見視圖不更新的情況,下面這篇文章主要給大家介紹了關于vuex更新視圖引發(fā)的一些思考,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

vuex可以集中式存儲管理應用的所有組件的狀態(tài),當 Vue 組件從 store 中讀取狀態(tài)的時候,若 store 中的狀態(tài)發(fā)生變化,那么相應的組件也會相應地得到高效更新

但是,最近踩了vuex的坑:

場景

  • 第一次進入頁面加載數(shù)據(jù),數(shù)據(jù)不顯示,點擊某個按鈕或者切換頁面后,數(shù)據(jù)會展示出來
  • 通過分析發(fā)現(xiàn),當?shù)谝淮渭虞d頁面的時候,獲取數(shù)據(jù)的數(shù)據(jù)為{} (空對象),當數(shù)據(jù)獲取完畢,執(zhí)行commit()
  • 而此時通過commit()已經(jīng)改變了state中的數(shù)據(jù),在頁面中通過computed也可以獲取更新后的數(shù)據(jù)。但是視圖沒有更新,獲取的數(shù)據(jù)沒有展示出來

解決

  • 嘗試在頁面中發(fā)送commit()來再次更新視圖,無效

  • 將Vue.set(state, 'myData', data),無效

  • ......

最終方案:

代碼中所聲明的對象里面的key是動態(tài)的,所以初始只聲明了{ }。

原來,數(shù)據(jù)是數(shù)組的時候,不能通過索引直接進行賦值,也不能修改數(shù)組的長度。 而Vuex只會跟蹤在對象創(chuàng)建時就存在的屬性,新添加到對象上的新屬性不會觸發(fā)更新。

并且循環(huán)嵌套層級太深,視圖也可能不更新

最終,給數(shù)組對象賦值,這里轉化了一下寫法,生效。具體如下:

const store = new Vuex.Store({
  state: {
    myData: []
  },
  mutations: {
    setData(state, data) {
      // state.myData = data  不更新視圖
      Vue.set(state, 'myData', JSON.parse(JSON.stringify(data)))
    }
  },
  actions: {
    myFn () {
      store.commit('setData')
    }
  }
})

export default store

如果添加了新的對象屬性,也可以使用Object.assign(),但必須深拷貝(否則加到對象上的新屬性不會觸發(fā)更新)

let someObject = Object.assign({}, someObject, {newField: value}) // 深拷貝
// Object.assign(this.someObject, { key: 1 }) // 淺拷貝

總結

  • 不能直接去改變 store 中的狀態(tài)。改變 store 中的狀態(tài)的需要提交 (commit) mutation
  • 在組件中調(diào)用 store 中的狀態(tài)在計算屬性中返回即可獲取,也可以直接$store.state來獲取
computed: {
    myData () {
      return store.state.myData
    }
},
mounted() {
    console.log(this.store.state.myData)
}
  • 為數(shù)組添加新屬性并不會觸發(fā)視圖更新,因為vue沒有給新屬性增加get和set監(jiān)聽

  • 賦值的數(shù)據(jù),如果循環(huán)嵌套層級太深,可能會導致視圖不更新

擴展

這些方法操作數(shù)組,vue可以檢測到數(shù)據(jù)變化:

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

而下面這些不會改變原數(shù)組(返回了新數(shù)組),vue檢測不到:

filter()
concat()
slice()

到此這篇關于vuex更新視圖引發(fā)的一些思考的文章就介紹到這了,更多相關vuex更新視圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue.js簡易安裝和快速入門(第二課)

    Vue.js簡易安裝和快速入門(第二課)

    這篇文章主要為大家詳細介紹了Vue.js簡易安裝和快速入門的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 使用VitePress搭建及部署vue組件庫文檔的示例詳解

    使用VitePress搭建及部署vue組件庫文檔的示例詳解

    這篇文章主要介紹了使用VitePress搭建及部署vue組件庫文檔,本文以element-plus作為示例來搭建一個文檔,結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • Vue源碼解析之Template轉化為AST的實現(xiàn)方法

    Vue源碼解析之Template轉化為AST的實現(xiàn)方法

    這篇文章主要介紹了Vue源碼解析之Template轉化為AST的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • 詳解vue 項目白屏解決方案

    詳解vue 項目白屏解決方案

    這篇文章主要介紹了詳解vue 項目白屏解決方案,詳細的介紹了白屏的解決方案,非常具有實用價值,需要的朋友可以參考下
    2018-10-10
  • 一篇帶你搞懂Vue中的自定義指令

    一篇帶你搞懂Vue中的自定義指令

    自定義指令,是Vue提供的一種擴展和定制的機制,使開發(fā)者能夠在組件中直接操作DOM、處理事件、添加樣式等,并提供了與第三方庫集成的方式,定義指令使得Vue在處理交互和DOM操作時更加靈活和強大,本文將帶大家搞懂Vue中的自定義指令,需要的朋友可以參考下
    2023-07-07
  • Vue實現(xiàn)Excel預覽功能使用場景示例詳解

    Vue實現(xiàn)Excel預覽功能使用場景示例詳解

    這篇文章主要為大家介紹了Vue實現(xiàn)Excel預覽功能使用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • vue運行環(huán)境搭建全過程

    vue運行環(huán)境搭建全過程

    這篇文章主要介紹了vue運行環(huán)境搭建全過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue實現(xiàn)單行刪除與批量刪除

    Vue實現(xiàn)單行刪除與批量刪除

    這篇文章主要介紹了Vue實現(xiàn)單行刪除與批量刪除,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)

    vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)

    最近工作中實現(xiàn)的一個效果不錯,分享給大家,下面這篇文章主要給大家介紹了關于vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • Vue 滾動行為的具體使用方法

    Vue 滾動行為的具體使用方法

    本篇文章主要介紹了Vue 滾動行為的具體使用方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09

最新評論