溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

vue.js狀態(tài)管理vuex中store怎么用

發(fā)布時(shí)間:2021-07-27 13:59:38 來(lái)源:億速云 閱讀:130 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹vue.js狀態(tài)管理vuex中store怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

一、狀態(tài)管理(vuex)簡(jiǎn)介

vuex是專(zhuān)為vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。vuex也集成刀vue的官方調(diào)試工具devtools extension,提供了諸如零配置的time-travel調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級(jí)調(diào)試功能。

二、狀態(tài)管理核心

狀態(tài)管理有5個(gè)核心,分別是state、getter、mutation、action以及module。分別簡(jiǎn)單的介紹一下它們:

1、state

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

2、getter

getter有點(diǎn)類(lèi)似vue.js的計(jì)算屬性,當(dāng)我們需要從store的state中派生出一些狀態(tài),那么我們就需要使用getter,getter會(huì)接收state作為第一個(gè)參數(shù),而且getter的返回值會(huì)根據(jù)它的依賴(lài)被緩存起來(lái),只有g(shù)etter中的依賴(lài)值(state中的某個(gè)需要派生狀態(tài)的值)發(fā)生改變的時(shí)候才會(huì)被重新計(jì)算。

3、mutation

更改store中state狀態(tài)的唯一方法就是提交mutation,就很類(lèi)似事件。每個(gè)mutation都有一個(gè)字符串類(lèi)型的事件類(lèi)型和一個(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中可以有任何的異步操作。在頁(yè)面中如果我們要嗲用這個(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請(qǐng)求也可以把a(bǔ)xios寫(xiě)在等號(hào)后面)

  }

}



const action={

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

}

這樣一個(gè)簡(jiǎn)單的store.js就已經(jīng)完成了。

在界面中我們要怎么使用這個(gè)建立的狀態(tài)管理呢:

首先在script下引入store.js

<script>

import store from 'store.js的路徑'

data(){

  return{

    userList:store.state.userList;//引入state中的對(duì)象

  }

},

methods:{

  useAction(){

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

      store.dispatch('setUserList',item);

  }

}

</script>

以上是“vue.js狀態(tài)管理vuex中store怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI