一、狀態(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ì)算去件。
如果不需要緩存的話坡椒,需要寫(xiě)成方法 -
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è) index.js景殷。 在index.js中引入 vue
和 vuex
在有需要的時(shí)候可以引入 axios溅呢。
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const state = {
userList: [1, 2, 3, 4]
}
const getters = {
getUrlParams: () => () => {
let url = location.search;
let theRequest = {};
if (url.indexOf("?") != -1) {
var str = url.substr(1), strs;
strs = str.split("&");
for (var i = 0; i < strs.length; i++) {
theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
}
}
return theRequest;
},
getUserList: (state) => {
//注:這里會(huì)緩存,只有執(zhí)行了 actions猿挚,這里的緩存才會(huì)更新
return state.userList;
}
}
const mutations = {
setUserList(state, data){
// 如果這里的 userList 接口返回咐旧,可以用axios請(qǐng)求
state.userList=data;
}
}
const actions = {
commitUserList:({commit}, userList) => commit('setUserList',userList)
}
const store = new Vuex.Store({
state: state,
getters: getters,
mutations: mutations,
actions: actions
})
export default store;
這樣一個(gè)簡(jiǎn)單的 store 就已經(jīng)完成了。
在界面中我們要怎么使用這個(gè)建立的狀態(tài)管理呢:
- 首先在main.js 引入 store:
import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store'
//實(shí)例化 vue
new Vue({
el: '#app',
store,
router,
components: { App },
template: '<App/>'
})
- 然后在
components
目錄 新建組件index.vue
, 組件里面就可以如下寫(xiě):
<template>
<ul>
<li v-for="(user, index) in userList">{{index}} --- {{user}}</li>
</ul>
<div @click="updateUserList()">更新用戶(hù)列表</div>
</template>
<script>
export default {
name: "index",
data() {
return{
userList: this.$store.getters.getUserList;//引入state中的對(duì)象
}
},
methods:{
updateUserList () {
var item=['a':'b','c':'d'];
this.$store.dispatch('setUserList', item);
}
}
}
</script>
- router 里面設(shè)置訪問(wèn)地址
import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router);
export default new Router({
mode: 'history', //目前使用 history 模式
routes: [
{
path: '/',
name: 'index',
component: resolve => require.ensure([], () => resolve(require('@/components/index.vue')), 'index')
}
]
})
相關(guān)文章