vuex的五個屬性是:1、state屬性,用來儲存變數;2、getters屬性,相當於state的計算屬性;3、mutations屬性,用於提交更新資料;4、actions屬性;5、modules屬性,用於模組化vuex。
推薦:《vue教學》
vue中vuex的五個屬性與基本用法
VueX 是一個專為Vue.js 應用設計的狀態管理架構,統一管理和維護各個vue元件的可變化狀態(你可以理解成vue 元件裡的某些data )。
Vuex有五個核心概念:
state
,getters
,mutations
,actions
,modules
。
1. state:vuex的基本數據,用來儲存變數
2. geeter:從基本資料(state)衍生的數據,相當於state的計算屬性
3. mutation:提交更新資料的方法,必須是同步的(如果需要非同步使用action)。每個 mutation 都有一個字串的 事件類型 (type) 和 一個 回呼函數 (handler)。
回呼函數就是我們實際進行狀態變更的地方,而且它會接受 state 作為第一個參數,提交載重作為第二個參數。
4. action:和mutation的功能大致相同,不同之處在於 ==》1. Action 提交的是 mutation,而不是直接變更狀態。 2. Action 可以包含任意非同步操作。
5. modules:模組化vuex,可以讓每個模組擁有自己的state、mutation、action、getters,使得結構非常清晰,方便管理。
Vuex的用法:
新vue專案testApp ==》 在testApp建置store檔==》 store檔下又有modules資料夾和getter.js 和index.js == 》 store檔案下建user.js
在專案的main.js中引入 import store from './store'
在store檔案下的index.js中引入
#import Vue from 'vue' import Vuex from 'vuex' import user from './modules/user' import global from './modules/global' import getters from './getters' Vue.use(Vuex) const store = new Vuex.Store({ modules: { user }, getters }) export default store 在store文件下的getters.js中引入 const getters = { self: state => state.user.self, token: state => state.user.token, currentCommunity: (state, getters) => { let cid = getters.currentCommunityId return getters.communities.filter(item => { return item.communityId === cid }) } } export default getters 在modules文件下的user.js写代码 const user = { state:{ self: null, token: '', }, mutations:{ SET_SELF: (state, self) => { state.self = self }, SET_TOKEN: (state, token) => { state.token = token } }, actions:{ login ({ commit }, res) { commit('SET_SELF', res.self) commit('SET_TOKEN', res.token } } export default user
使用下面這兩種方法儲存資料:
dispatch:异步操作,写法: this.$store.dispatch('mutations方法名',值) commit:同步操作,写法:this.$store.commit('mutations方法名',值)
以上是vuex的五個屬性是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!