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

Vuex中狀態(tài)管理器的使用詳解

 更新時(shí)間:2022年06月22日 17:12:17   作者:上庸往事  
這篇文章主要介紹了Vuex狀態(tài)管理器的使用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、Vuex是什么?

Vuex在Vue項(xiàng)目開發(fā)時(shí)使用的狀態(tài)管理工具。簡單來說,就是對(duì)Vue的應(yīng)用中多個(gè)組件的共享狀態(tài)進(jìn)行集中式的管理(讀/

Vuex實(shí)現(xiàn)了一個(gè)單向數(shù)據(jù)流,在全局擁有一個(gè)State存放數(shù)據(jù),當(dāng)組件要更改State中的數(shù)據(jù)時(shí),必須通過Mutation進(jìn)行,Mutation同時(shí)提供了訂閱者模式供外部插件調(diào)用獲取State數(shù)據(jù)的更新。

而當(dāng)所有異步操作(常見于調(diào)用后端接口異步獲取更新數(shù)據(jù))或批量的同步操作需要走Action,但Action也是無法直接修改State的,還是需要通過Mutation來修改State的數(shù)據(jù)。最后,根據(jù)State的變化,渲染到視圖上。

二、什么時(shí)候使用Vuex

不適用場景:小型簡單應(yīng)用,用 Vuex 是繁瑣冗余的,更適合使用簡單的store模式

適用場景:構(gòu)建一個(gè)中大型單頁應(yīng)用,可能會(huì)考慮如何更好地在組件外部管理狀態(tài),即多個(gè)組件共享狀態(tài):

多個(gè)視圖依賴于同一狀態(tài):此時(shí)傳參的方法對(duì)于多層嵌套的組件將會(huì)非常繁瑣,并且對(duì)于兄弟組件間的狀態(tài)傳遞無能為力。

來自不同視圖的行為需要變更同一狀態(tài)此時(shí)采用父子組件直接引用或者通過事件來變更和同步狀態(tài)的多份拷貝,通常會(huì)導(dǎo)致無法維護(hù)的代碼

在這些情況下就適合用Vuex進(jìn)行全局單例模式管理

三、Vuex的核心概念和API

流程:View -> Actions -> Mutations -> State -> View

 

1、state

1) vuex 管理的狀態(tài)對(duì)象

2) 它應(yīng)該是唯一的

const state = {
xxx: initValue
}

2、 mutations

1) 包含多個(gè)直接更新 state 的方法(回調(diào)函數(shù))的對(duì)象

2) 誰來觸發(fā): action 中的 commit('mutation 名稱')或者在組件中通過this.$store.commit(‘xxx’,params)使用。這個(gè)和組件中的自定義事件類似

3) 只能包含同步的代碼, 不能寫異步代碼

const mutations = {
xxx(state, {data1}) {
// 更新 state 的某個(gè)屬性
}
}

3、 actions

1) 提交 mutation,異步操作。包含多個(gè)事件回調(diào)函數(shù)的

2) 通過執(zhí)行: commit()來觸發(fā) mutation 的調(diào)用, 間接更新 state

3) 誰來觸發(fā): 組件中通過this.$store.dispatch('action 名稱', data1)

4) 可以包含異步代碼(axios)

const actions ={
zzz ({commit, state}, data1){
commit('xxx', {data1})
}
}

4、 getters

1) 對(duì)數(shù)據(jù)獲取之前的再次編譯,可以理解為state的計(jì)算屬性

2) 誰來讀取: 組件中: this.$store.getters.xxx

const getters ={
xxx(state) {
return ...
}
}

5、 modules

1) 包含多個(gè) module:store的子模塊,為了開發(fā)大型項(xiàng)目,方便狀態(tài)管理而使用的,即將store分割為模塊,使store對(duì)象不會(huì)太臃腫。

2)一個(gè) module 是一個(gè) store 的配置對(duì)象

3) 與一個(gè)組件(包含有共享數(shù)據(jù))對(duì)應(yīng)

四、應(yīng)用舉例

1、安裝:npm i vuex -S

2、創(chuàng)建store:src/store/index.js

import { createStore} from "vuex";
export default createStore({
    //vuex中的數(shù)據(jù)源,我們需要保存的數(shù)據(jù)就保存在這里,可以在組件通過 this.$store.state來獲取我們定義的數(shù)據(jù);
    state: {
        count: 0,
        age: 0
    },
    /*
      (1)Getter相當(dāng)于vue中的computed計(jì)算屬性,getter 的返回值會(huì)根據(jù)它的依賴被緩存起來,且只有當(dāng)它的依賴值發(fā)生了改變才會(huì)被重新計(jì)算
      (2)通過屬性訪問Getter會(huì)暴露為 store.getters 對(duì)象,可以以屬性的形式訪問這些值:this.$store.getters.xxx
      (3)Getters 可以用于監(jiān)聽state中的值的變化,返回計(jì)算后的結(jié)果
    */
    getters: {
        getterAge(state){
            return state.age =25
        }
    },
    /*
       更改 Vuex 的 store 中的狀態(tài)的唯一方法是提交 mutation,并且Mutation 必須是同步函數(shù)
       在sotre.js中定義mutations對(duì)象,該對(duì)象中有兩個(gè)方法,mutations里面的參數(shù),第一個(gè)默認(rèn)為state,
       其中第二個(gè)參數(shù)obj在官方文檔就是載荷(payload),可以傳入?yún)?shù)及對(duì)象。
       在大多數(shù)情況下,載荷應(yīng)該是一個(gè)對(duì)象,這樣可以包含多個(gè)字段并且記錄的 mutation 會(huì)更易讀
     */
    mutations: {
        addCount(state,obj){
            return state.count += obj.num
        },
        subCount(state,obj){
            return state.count -= obj.num
        }
    },
    actions: {
        addCountAsyn(context){
            setTimeout(()=>{
                context.commit('addCount',{
                    num: 1
                })
            },3000)
        },
        subCountAsyn(context){
            setTimeout(()=> {
                context.commit('subCount',{
                    num: 1
                })
            },2000)
        }
    }
})

3、在main.js文件中使用store

4、創(chuàng)建Home.vue組件

<template>
  <div>
    <h2>通過getter獲得計(jì)算后的年齡:{{ getterAge }}</h2>
    <p>Count:{{ count }}</p>
    <button @click="handlerAdd()">加1</button>
    <button @click="handlerSub()">減1</button>
    <button @click="handlerAddAnys()">異步增加(2s后執(zhí)行)</button>
    <button @click="handlerSubAnys()">異步減少(2s后執(zhí)行)</button>
  </div>
</template>
 
<script>
export default {
  name: "Home",
  computed: {
    count(){
      return this.$store.state.count
    },
    getterAge(){
      return this.$store.getters.getterAge
    }
   },
  methods: {
    handlerAdd(){
      this.$store.commit("addCount",{
        num: 1
      })
    },
    handlerSub(){
      this.$store.commit("subCount",{
        num: 1
      })
    },
    handlerAddAnys(){
      this.$store.dispatch('addCountAsyn')
    },
    handlerSubAnys(){
      this.$store.dispatch('subCountAsyn')
    }
   }
}
</script>

6、在App.vue中導(dǎo)入Home.vue

7、運(yùn)行效果:

五、vuex中各種輔助函數(shù)的用法,可以使我們更加方便的運(yùn)用vuex

1、…mapState

count(){
     return this.$store.state.count
},

等價(jià)于

...mapState([
  'count'
]),

2、…mapGetters

getterAge(){
  return this.$store.getters.getterAge
}

等價(jià)于

...mapGetters(['getterAge'])    

3、…mapMutations:使用輔助函數(shù)后載荷的傳參,直接在調(diào)用的地方進(jìn)行傳參便可

handlerAdd(){
  this.$store.commit("addCount",{
    num: 1
  })
},
handlerSub(){
  this.$store.commit("subCount",{
    num: 1
  })
},

等價(jià)于

...mapMutations({
  handlerAdd: 'addCount',
  handlerSub: 'subCount'
})

4、…mapActions

handlerAddAnys(){
  this.$store.dispatch('addCountAsyn')
},
handlerSubAnys(){
  this.$store.dispatch('subCountAsyn')
}

等價(jià)于

...mapActions({
  handlerAddAnys: 'addCountAsyn',
  handlerSubAnys: 'subCountAsyn'
})

修改上例中的Home.vue組件

到此這篇關(guān)于Vuex---狀態(tài)管理器的使用的文章就介紹到這了,更多相關(guān)Vuex狀態(tài)管理器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue組件渲染與更新實(shí)現(xiàn)過程淺析

    Vue組件渲染與更新實(shí)現(xiàn)過程淺析

    這篇文章主要介紹了Vue組件渲染與更新實(shí)現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-03-03
  • 詳解vue中this.$emit()的返回值是什么

    詳解vue中this.$emit()的返回值是什么

    這篇文章主要介紹了詳解vue中this.$emit()的返回值是什么,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 深入了解Vue使用vue-qr生成二維碼的方法

    深入了解Vue使用vue-qr生成二維碼的方法

    這篇文章主要為大家介紹了Vue使用vue-qr生成二維碼的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Vue常用傳值方式、父傳子、子傳父及非父子實(shí)例分析

    Vue常用傳值方式、父傳子、子傳父及非父子實(shí)例分析

    這篇文章主要介紹了Vue常用傳值方式、父傳子、子傳父及非父子,結(jié)合實(shí)例形式分析了vue.js常見的傳值方式及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • Vue的v-if和v-show的區(qū)別圖文介紹

    Vue的v-if和v-show的區(qū)別圖文介紹

    這篇文章主要介紹了Vue的v-if和v-show的區(qū)別圖文介紹,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 解決vue初始化項(xiàng)目時(shí),一直卡在Project description上的問題

    解決vue初始化項(xiàng)目時(shí),一直卡在Project description上的問題

    今天小編就為大家分享一篇解決vue初始化項(xiàng)目時(shí),一直卡在Project description上的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue項(xiàng)目關(guān)閉eslint校驗(yàn)

    vue項(xiàng)目關(guān)閉eslint校驗(yàn)

    eslint是一個(gè)JavaScript的校驗(yàn)插件,通常用來校驗(yàn)語法或代碼的書寫風(fēng)格。這篇文章主要介紹了vue項(xiàng)目關(guān)閉eslint校驗(yàn),需要的朋友可以參考下
    2018-03-03
  • VUEX如何使用

    VUEX如何使用

    Vuex?可以幫助我們管理共享狀態(tài),并附帶了更多的概念和框架,本文主要介紹了VUEX如何使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue+elementUI實(shí)現(xiàn)動(dòng)態(tài)合并數(shù)據(jù)相同的單元格(可指定合并列)

    vue+elementUI實(shí)現(xiàn)動(dòng)態(tài)合并數(shù)據(jù)相同的單元格(可指定合并列)

    這篇文章主要介紹了vue+elementUI如何實(shí)現(xiàn)動(dòng)態(tài)合并數(shù)據(jù)相同的單元格,文中有詳細(xì)的代碼實(shí)例供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-07-07
  • vue打包項(xiàng)目版本號(hào)自加的操作步驟

    vue打包項(xiàng)目版本號(hào)自加的操作步驟

    項(xiàng)目每次打包后都需要改動(dòng)項(xiàng)目版本號(hào),這個(gè)改動(dòng)每次都需要在package.json中修改version,比較麻煩,到底有沒有一種打包后版本號(hào)自加的辦法,這篇文章主要介紹了vue打包項(xiàng)目版本號(hào)自加的步驟,需要的朋友可以參考下
    2022-09-09

最新評(píng)論