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

Vuex中mutations的用法及說明

 更新時間:2024年01月25日 08:56:57   作者:小何同學(xué)要加油  
這篇文章主要介紹了Vuex中mutations的用法及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

Vuex中mutations用法

在 Vuex 中 store 數(shù)據(jù)改變的唯一方法就是提交 mutations

mutations里面裝著一些改變數(shù)據(jù)方法的集合,這是Vuex 設(shè)計很重要的一點,就是把處理數(shù)據(jù)邏輯方法全部放在 mutations 里面,使得數(shù)據(jù)和視圖分離。

Mutations使用

Vuex 中的 mutations 非常類似于事件,每個 mutations 都有一個字符串的事件類型(type)和一個回調(diào)函數(shù)(handler),也可以理解為{type:handler()},這和訂閱發(fā)布有點類似。

先注冊事件,當觸發(fā)響應(yīng)類型的時候調(diào)用handker(),調(diào)用type的時候需要用到store.commit方法。

示例:

這個回調(diào)函數(shù)會接受state 作為第一個參數(shù):

const store = new Vuex.Store({
  state: {
    count: 1
  },
  mutations: {
     // 事件類型 type 為 increment
    increment (state) { 
      // 變更狀態(tài)
      state.count++
    }
  }
})

我們不能直接使用store.mutations.increment() 來調(diào)用,Vuex 規(guī)定必須使用 store.commit 來觸發(fā)對應(yīng) type 的方法:

store.commit('increment')

提交載荷(Payload)

載荷簡單的理解就是往 handler(state) 中傳參 handler(state, pryload) 。

示例:

大多數(shù)情況下,載荷是一個對象:

mutations: {
 // 提交荷載
 increment (state, payload) {
  state.count += payload.amount
 }
}

提交荷載有兩種方式:

// 把載荷和type分開提交
store.commit('increment', {
 amount: 10
})
 
// 整個對象都作為載荷傳給mutation函數(shù)
store.commit({
 type: 'increment',
 amount: 10
})

我們可以根據(jù)自己的方式來選擇使用哪種提交方式。

commit 我們可以在組件中使用 this.$store.commit(‘xxx’) 提交 mutations。

示例:

或者可以使用 mapMutations 輔助函數(shù)將組件中的 methods 映射為 store.commit 調(diào)用(需要在根節(jié)點注入 store)。

示例:

在使用mapMutations 輔助函數(shù)之前同樣需要先引入:

<script>
import { mapMutations } from 'vuex'
export default {
  computed:{
    count(){
      return this.$store.state.count
    }
  },
  methods:{
    ...mapMutations([//采用解構(gòu)的方式引入
      'increment',
      'decrement'
    ])
  }
}
</script>

Mutations 需遵守 Vue 的響應(yīng)規(guī)則

Vuex 的 store 中的狀態(tài)是響應(yīng)式的,所以當我們變更狀態(tài)時,監(jiān)視狀態(tài)的 Vue 組件也會自動更新。

這也意味著 Vuex 中的 mutations 也需要與使用 Vue 一樣遵守一些注意事項,如下所示:

最好提前在 store 中初始化好所有所需屬性。

當需要在對象上添加新屬性時,應(yīng)該使用 Vue.set(obj, ‘newProp’, 123),或者以新對象替換老對象。

例如利用對象展開運算符可以寫成:state.obj = {…state.obj, newProp: 123 }。

使用常量替代 Mutations 事件類型

使用常量替代 mutations 事件類型在各種 Flux 實現(xiàn)中是很常見的模式。

這樣可以使 linter 之類的工具發(fā)揮作用,同時把這些常量放在單獨的文件中可以讓你的代碼合作者對整個 app 包含的 mutations 一目了然:

// mutation-types.js
export const SOME_MUTATION = 'SOME_MUTATION'

store.js 文件內(nèi)容如下所示:

// store.js
import Vuex from 'vuex'
import { SOME_MUTATION } from './mutation-types'
 
const store = new Vuex.Store({
 state: { ... },
 mutations: {
  // 使用 ES2015 風(fēng)格的計算屬性命名功能來使用一個常量作為函數(shù)名
  [SOME_MUTATION] (state) {
   // mutate state
  }
 }
})

我們知道m(xù)utation 是通過store.commit(‘increment’)的方式調(diào)用的,其中increment方法是以字符串的形式代入。

如果項目小,一個人開發(fā)的話倒還好,但是項目大了,編寫代碼的人多了,那就麻煩了,因為需要 commit 的方法一多,就會顯得特別混亂,而且以字符串形式代入的話,一旦出了錯,很難排查。

所以,在需要多人協(xié)作的大型項目中,最好還是用常量的形式來處理 mutation。

必須是同步函數(shù)

我們要記住的是,Mutation 必須是同步函數(shù)。

因為我們之所以要通過提交 mutation 的方式來改變狀態(tài)數(shù)據(jù),是因為我們想要更明確地追蹤到狀態(tài)的變化。

如果是類似下面這樣異步的話:

mutations: {
 someMutation (state) {
  api.callAsyncMethod(() => {
   state.count++
  })
 }
}

我們就不知道什么時候狀態(tài)會發(fā)生改變,所以也就無法追蹤了,這與 Mutation 的設(shè)計初心相悖,所以強制規(guī)定它必須是同步函數(shù)。

store.commit('increment') // 任何由'increment'導(dǎo)致的狀態(tài)變更都應(yīng)該在此刻完成

需求:

點擊不同的音樂列表就讓下方播放列表顯示自己點擊的列表,音樂列表是循環(huán)的

實現(xiàn)方式:

就是利用vuex中的mutations。在mutations中定義一個方法,這個方法就是把點擊的index(也就是每個列表的唯一標識),傳給state中的當前標識。

在循環(huán)列表的頁面,把setPlayIndex方法引用過來用到頁面中,點擊不同的列表傳不同的index也就是setPlayIndex方法中的不同的value。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue.js異步上傳文件前后端實現(xiàn)代碼

    vue.js異步上傳文件前后端實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了vue.js異步上傳文件前后端的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 詳解Vue.js——60分鐘組件快速入門(上篇)

    詳解Vue.js——60分鐘組件快速入門(上篇)

    本篇文章主要介紹了Vue.js組件,組件系統(tǒng)是Vue.js其中一個重要的概念,具有一定的參考價值,有需要的可以了解一下。
    2016-12-12
  • Vue通過moment插件實現(xiàn)獲取當前月的第一天和最后一天

    Vue通過moment插件實現(xiàn)獲取當前月的第一天和最后一天

    這篇文章主要介紹了Vue 結(jié)合插件moment 實現(xiàn)獲取當前月的第一天和最后一天,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-10-10
  • Vue?項目中選擇?TSX?而非傳統(tǒng)?.vue?文件的原因分析

    Vue?項目中選擇?TSX?而非傳統(tǒng)?.vue?文件的原因分析

    文章探討了Vue項目中使用TSX(TypeScript?JSX)的背景、優(yōu)勢和局限性,TSX結(jié)合了TypeScript和JSX,增強了類型安全和代碼組織性,但也增加了學(xué)習(xí)曲線和可讀性問題,對于復(fù)雜應(yīng)用,TSX提供了更大的靈活性和類型支持,逐漸成為一些開發(fā)者的選擇
    2024-11-11
  • 一文搞明白vue開發(fā)者vite多環(huán)境配置

    一文搞明白vue開發(fā)者vite多環(huán)境配置

    Vue是一款流行的JavaScript框架,用于開發(fā)動態(tài)單頁應(yīng)用程序,本地安裝和環(huán)境配置是學(xué)習(xí)和使用Vue的第一步,下面這篇文章主要給大家介紹了關(guān)于vue開發(fā)者vite多環(huán)境配置的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • Vue中指令v-model的原理及使用方法

    Vue中指令v-model的原理及使用方法

    v-model是Vue中的一個重要語法糖,主要用于實現(xiàn)數(shù)據(jù)的雙向綁定,它通過結(jié)合value屬性和input事件,簡化了代碼并提高了開發(fā)效率,文中通過代碼介紹的非常詳解,需要的朋友可以參考下
    2024-09-09
  • vue如何通過$router.push傳參數(shù)

    vue如何通過$router.push傳參數(shù)

    這篇文章主要介紹了vue如何通過$router.push傳參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vuejs 頁面的區(qū)域化與組件封裝的實現(xiàn)

    Vuejs 頁面的區(qū)域化與組件封裝的實現(xiàn)

    本篇文章主要介紹了Vuejs 頁面的區(qū)域化與組件封裝的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 實現(xiàn)Vue的markdown文檔可以在線運行的方法示例

    實現(xiàn)Vue的markdown文檔可以在線運行的方法示例

    這篇文章主要介紹了實現(xiàn)Vue的markdown文檔可以在線運行的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue組件中傳值EventBus的使用及注意事項說明

    vue組件中傳值EventBus的使用及注意事項說明

    這篇文章主要介紹了vue組件中傳值EventBus的使用及注意事項說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論