vue.js的狀態管理vuex中store的使用


一、狀態管理(vuex)簡介

        vuex是專為vue.js應用程序開發的狀態管理模式。它采用集中存儲管理應用的所有組件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。vuex也集成刀vue的官方調試工具devtools extension,提供了諸如零配置的time-travel調試、狀態快照導入導出等高級調試功能。

 

二、狀態管理核心

狀態管理有5個核心,分別是state、getter、mutation、action以及module。分別簡單的介紹一下它們:

1、state

        state為單一狀態樹,在state中需要定義我們所需要管理的數組、對象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個對象的狀態。

2、getter

        getter有點類似vue.js的計算屬性,當我們需要從store的state中派生出一些狀態,那么我們就需要使用getter,getter會接收state作為第一個參數,而且getter的返回值會根據它的依賴被緩存起來,只有getter中的依賴值(state中的某個需要派生狀態的值)發生改變的時候才會被重新計算。

3、mutation

        更改store中state狀態的唯一方法就是提交mutation,就很類似事件。每個mutation都有一個字符串類型的事件類型和一個回調函數,我們需要改變state的值就要在回調函數中改變。我們要執行這個回調函數,那么我們需要執行一個相應的調用方法:store.commit。

4、action

        action可以提交mutation,在action中可以執行store.commit,而且action中可以有任何的異步操作。在頁面中如果我們要嗲用這個action,則需要執行store.dispatch

5、module

        module其實只是解決了當state中很復雜臃腫的時候,module可以將store分割成模塊,每個模塊中擁有自己的state、mutation、action和getter。

 

三、實例

首先建立一個vue.js項目,然后引入vuex

npm install vuex --save

而后建立一個store文件夾,建立一個store.js。在store.js中引入vue和vuex、在有需要的時候可以引入axios。

import vue from 'vue'

import  vuex from 'vuex'

vue.use(vuex)

const state={

    userList:[]

}

 

const mutations={

    setUserList(state,data){

        state.userList=data;

        (注:如果這里的userList需要axios請求也可以把axios寫在等號后面)

    }

}

 

const action={

    commitUserList:({commit},userList)=>commit('setUserList',userList)

}

這樣一個簡單的store.js就已經完成了。

在界面中我們要怎么使用這個建立的狀態管理呢:

首先在script下引入store.js

<script>

import store from 'store.js的路徑'

data(){

    return{

        userList:store.state.userList;//引入state中的對象

    }

},

methods:{

    useAction(){

            var item=['1':'2','a':'c'];

            store.dispatch('setUserList',item);

    }

}

</script>


————————————————
版權聲明:本文為CSDN博主「zeternityyt」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/zeternityyt/article/details/80041526


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM