




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第10章vuex狀態(tài)管理器
什么是vuexVuex是一個(gè)專為Vue應(yīng)用程序開發(fā)的狀態(tài)(數(shù)據(jù))管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài)(數(shù)據(jù))。每一個(gè)Vuex應(yīng)用的核心就是store(倉(cāng)庫(kù)),即響應(yīng)式容器,它用來定義應(yīng)用中數(shù)據(jù)以及數(shù)據(jù)處理工具。Vuex的狀態(tài)存儲(chǔ)是響應(yīng)式的,當(dāng)store中數(shù)據(jù)狀態(tài)發(fā)生變化,那么頁(yè)面中的store數(shù)據(jù)也發(fā)生相應(yīng)變化。改變store中的狀態(tài)的唯一途徑就是顯式地提交mutation,這樣可以方便地跟蹤每一個(gè)狀態(tài)的變化。Vuex的下載和安裝(1)下載vuex.js登錄下載地址/zh/installation.html,下載vuex.js存放在項(xiàng)目js文件夾之下。(2)引入在HTML頁(yè)面先引入Vue.js,后接著引入Vuex.js。<script
src="js/vue.js"></script><script
src="js/vuex.js"></script>在Vue.js之后引入vuex.js,vuex.js會(huì)進(jìn)行自動(dòng)安裝。Vuex基本使用(1)創(chuàng)建store實(shí)例通過new關(guān)鍵字實(shí)例化一個(gè)store實(shí)例,該實(shí)例是單一的狀態(tài)樹(數(shù)據(jù)倉(cāng)庫(kù))。創(chuàng)建store實(shí)例語(yǔ)法:newVuex.store({state:{},//狀態(tài),組件中需要共享使用的數(shù)據(jù)mutations:{},//改變狀態(tài)的唯一方式就是提交mutation,同步改變狀態(tài) getters:{},//類似計(jì)算屬性actions:{}//用于異步更新狀態(tài)})(2)將store實(shí)例注入到Vue根實(shí)例上
var
vm
=
new
Vue({
el:
'#app',
store,
});
通過在根實(shí)例中注冊(cè)store選項(xiàng),該store實(shí)例會(huì)注入到根組件下的所有子組件中,且子組件能通過this.$store訪問到store中的數(shù)據(jù)。
Vuex配置選項(xiàng)1、state配置選項(xiàng)Vuex的狀態(tài)存儲(chǔ)是響應(yīng)式,即store中的狀態(tài)是響應(yīng)式的,在組件調(diào)用store中的狀態(tài)時(shí)僅需要在計(jì)算屬性中返回即可。通過“this.$store.state.key(字段名)”訪問到store中數(shù)據(jù)mapState輔助函數(shù):當(dāng)一個(gè)組件需要獲取多個(gè)狀態(tài)時(shí),將這些狀態(tài)都聲明為計(jì)算屬性有些麻煩,這時(shí)候可以使用mapState輔助函數(shù)來生成計(jì)算屬性。(1)數(shù)組寫法:…mapState([‘字段key’])例如:
...mapState(["name","gender","age"])(2)對(duì)象寫法:…mapState({自定名1:‘字段key’,……})例如:
...mapState({
xm:
"name",
xb:"gender",
nl:
"age"})在一個(gè)模塊化的打包系統(tǒng)中通過import{mapState}from“vuex”引入Vuex配置選項(xiàng)2、
getters配置選項(xiàng)有時(shí)候在數(shù)據(jù)使用前,需要進(jìn)行一些處理,即從store中派生出一些狀態(tài)(數(shù)據(jù)),Vuex在
store中定義“getter”選項(xiàng)(可以認(rèn)為是store的計(jì)算屬性),來派生出一些狀態(tài)。在組件中使用getters,通過“this.$store.getters.函數(shù)名”直接獲取,也可以通過輔助函數(shù)mapGetters。數(shù)組寫法:…mapgetteers([‘函數(shù)名’])對(duì)象寫法:…mapgetteers({key:‘函數(shù)名’})Vuex配置選項(xiàng)3、mutations配置選項(xiàng)需要修改store(倉(cāng)庫(kù))中的數(shù)據(jù),唯一途徑就是顯式地mommit提交mutation,mutation必須是同步函數(shù)。mutations:{
函數(shù)名(state,payload){ //修改state的中的數(shù)據(jù)}在組件中提交Mutation方式:(1)this.$mit()提交this.$mit(‘函數(shù)名’,參數(shù)對(duì)象)(2)輔助函數(shù)mapMutations數(shù)組寫法:…mapMutations([‘函數(shù)名’])對(duì)象寫法:…mapMutations({key:’函數(shù)名’})Vuex配置選項(xiàng)4、
actions配置選項(xiàng)Action是異步修改state的數(shù)據(jù)。異步修改state也需要提交一個(gè)mutation,才能達(dá)到修改的目的。actions:{
函數(shù)名({commit},paload){ commit(‘mutation中的函數(shù)名’)}}在組件中分發(fā)Action方式:(1)在組件中使用
this.$store.dispatch()
分發(fā)actionthis.$store.dispatch(‘函數(shù)名’,參數(shù)對(duì)象)或使用包含type屬性的對(duì)象this.$store.dispatch({type:’函數(shù)名’,key
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 房地產(chǎn)開發(fā)合作協(xié)議合同
- 三農(nóng)田改造方案設(shè)計(jì)指南
- 建筑木工分包合同
- 上海聲屏障施工方案
- 防水安全生產(chǎn)施工方案
- pvc地板膠施工方案
- 燜渣坑施工方案
- 余姚耐磨地坪施工方案
- 自建房水泥欄桿施工方案
- 青島市eps線條施工方案
- 2024-2025學(xué)年第二學(xué)期天域全國(guó)名校協(xié)作體高三3月聯(lián)考 語(yǔ)文試卷(含答案)
- 2025年中考百日誓師活動(dòng)教師代表發(fā)言(三)
- 中國(guó)家用通風(fēng)電器具制造行業(yè)分析報(bào)告
- 生物-天一大聯(lián)考2025屆高三四省聯(lián)考(陜晉青寧)試題和解析
- 天津2025年天津市住房公積金管理中心招聘9人筆試歷年參考題庫(kù)附帶答案詳解-1
- 區(qū)間價(jià)格突破策略(TB版)
- 高中主題班會(huì) 遠(yuǎn)離背后“蛐蛐”課件-高二下學(xué)期人際交往主題班會(huì)
- DeepSeek科普課件深度解析
- 大模型應(yīng)用服務(wù)平臺(tái)建設(shè)研究
- 2025年度智慧養(yǎng)老服務(wù)平臺(tái)開發(fā)與運(yùn)營(yíng)服務(wù)合同
- 2025年湖南科技職業(yè)學(xué)院高職單招語(yǔ)文2018-2024歷年參考題庫(kù)頻考點(diǎn)含答案解析
評(píng)論
0/150
提交評(píng)論