vue.js的狀態(tài)管理vuex中store的使用詳解
一、狀態(tài)管理(vuex)簡介
vuex是專為vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測的方式發(fā)生變化。vuex也集成刀vue的官方調(diào)試工具devtools extension,提供了諸如零配置的time-travel調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級調(diào)試功能。
二、狀態(tài)管理核心
狀態(tài)管理有5個(gè)核心,分別是state、getter、mutation、action以及module。分別簡單的介紹一下它們:
1、state
state為單一狀態(tài)樹,在state中需要定義我們所需要管理的數(shù)組、對象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個(gè)對象的狀態(tài)。
2、getter
getter有點(diǎn)類似vue.js的計(jì)算屬性,當(dāng)我們需要從store的state中派生出一些狀態(tài),那么我們就需要使用getter,getter會(huì)接收state作為第一個(gè)參數(shù),而且getter的返回值會(huì)根據(jù)它的依賴被緩存起來,只有g(shù)etter中的依賴值(state中的某個(gè)需要派生狀態(tài)的值)發(fā)生改變的時(shí)候才會(huì)被重新計(jì)算。
3、mutation
更改store中state狀態(tài)的唯一方法就是提交mutation,就很類似事件。每個(gè)mutation都有一個(gè)字符串類型的事件類型和一個(gè)回調(diào)函數(shù),我們需要改變state的值就要在回調(diào)函數(shù)中改變。我們要執(zhí)行這個(gè)回調(diào)函數(shù),那么我們需要執(zhí)行一個(gè)相應(yīng)的調(diào)用方法:store.commit。
4、action
action可以提交mutation,在action中可以執(zhí)行store.commit,而且action中可以有任何的異步操作。在頁面中如果我們要嗲用這個(gè)action,則需要執(zhí)行store.dispatch
5、module
module其實(shí)只是解決了當(dāng)state中很復(fù)雜臃腫的時(shí)候,module可以將store分割成模塊,每個(gè)模塊中擁有自己的state、mutation、action和getter。
三、實(shí)例
首先建立一個(gè)vue.js項(xiàng)目,然后引入vuex
npm install vuex --save
而后建立一個(gè)store文件夾,建立一個(gè)store.js。在store.js中引入vue和vuex、在有需要的時(shí)候可以引入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請求也可以把a(bǔ)xios寫在等號后面) } } const action={ commitUserList:({commit},userList)=>commit('setUserList',userList) }
這樣一個(gè)簡單的store.js就已經(jīng)完成了。
在界面中我們要怎么使用這個(gè)建立的狀態(tài)管理呢:
首先在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>
以上這篇vue.js的狀態(tài)管理vuex中store的使用詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue3實(shí)現(xiàn)監(jiān)聽store中state狀態(tài)變化的簡單方法
- vuex之this.$store.dispatch()與this.$store.commit()的區(qū)別及說明
- Vuex的store中的Module用法及說明
- vuex中this.$store.commit和this.$store.dispatch的基本用法實(shí)例
- vue data中如何獲取使用store中的變量
- vue3中router路由以及vuex的store使用解析
- 在Vue中使用this.$store或者是$route一直報(bào)錯(cuò)的解決
- Vue 關(guān)于Store的用法小結(jié)
相關(guān)文章
vue實(shí)現(xiàn)滑動(dòng)到底部加載更多效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)滑動(dòng)到底部加載更多效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08vue3使用xgPalyer實(shí)現(xiàn)截圖功能的方法詳解
這篇文章主要為大家詳細(xì)介紹了如何在vue3中使用xgPalyer截圖功能,以及自定義插件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02element plus tree拖動(dòng)節(jié)點(diǎn)交換位置和改變層級問題(解決方案)
圖層list里有各種組件,用element plus的tree來渲染,可以把圖片等組件到面板里,面板是容器,非容器組件,比如圖片、文本等,就不能讓其他組件拖進(jìn)來,這篇文章主要介紹了element plus tree拖動(dòng)節(jié)點(diǎn)交換位置和改變層級問題(解決方案),需要的朋友可以參考下2024-04-04axios+Vue實(shí)現(xiàn)上傳文件顯示進(jìn)度功能
這篇文章主要介紹了axios+Vue上傳文件顯示進(jìn)度效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04Vue 動(dòng)態(tài)生成數(shù)據(jù)字段的實(shí)例
這篇文章主要介紹了Vue 動(dòng)態(tài)生成數(shù)據(jù)字段的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04打包組件報(bào)錯(cuò):Error:Cannot?find?module?'vue/compiler-sfc&ap
最近遇到這樣的問題,vue組件庫搭建過程中使用webpack打包組件時(shí)報(bào)錯(cuò),本文給大家分享打包組件報(bào)錯(cuò):Error:?Cannot?find?module?‘vue/compiler-sfc‘的解決方法,感興趣的朋友一起看看吧2023-12-12