Vuex是官方提供的一个插件,状态管理库,集中式管理项目中组件共用的数据
中大型单页面应用,组件间关系复杂,组件状态多,组件间通信困难,这个时候就可以考虑使用Vuex
state:存放状态数据的地方,其中数据是响应式的,数据改变对应组件的数据也会跟新改变,禁止直接改变state中的数据否则数据无法被调试工具监测。
mutations:装着处理数据逻辑方法的集合体,是改变state中数据的唯一方法,修改数据是同步的。
actions:提交mutations修改数据,与mutations功能类似,但修改数据是异步的。
getter:可理解为store的计算属性,能读取state中的数据。
modules:当store过于臃肿时,可使用modules将store分割成模块,每个模块中都有自己的state、getter、mutations、actions
1、用Vue脚手架工具构建好项目;
2、利用npm包管理工具安装vuex;
3、新建一个store文件夹,并在文件夹下新建“index.js”文件;
4、在文件中引入vue和vuex。
npm install vuex --save
要注意的是这里加上 –save,因为这个包我们是在生产环境中是要使用的。
import Vue from "vue"
import Vuex from 'vuex'
Vue.use(Vuex)
const state ={
count: 1
}
const mutations ={
numAdd(state){
state.count++
}
}
const actions = {}
const getters = {}
// 利用Vuex.Store创建实例并暴露出去
export default new Vuex.Store({
state,
mutations,
actions,
getters,
//modules:{}
})
import Vue from 'vue'
import App from './App.vue'
// 引入vuex文件
import store from "@/store"
new Vue({
render: h => h(App),
router,
//注册
store
}).$mount('#app')
通过这几步的操作,vuex就算引用成功了,接下来我们就可以尽情的玩耍了。
this.$store.state.全局数据名称
例如,在组件Home.vue中使用,注意:在组件中可以省略this关键字
这是home首页
{{$store.state.home.count}}
这是home首页
computed:{
count(){
return this.$store.state.count;
}
}
这里需要注意的是return this.$store.state.count
这一句,一定要写this,要不你会找不到$store的。
通过commit一个mutation来修改状态
const mutations={
add(state){
state.count+=1;
},
reduce(state){
state.count-=1;
}
}
关于传值:这只是一个最简单的修改状态的操作,在实际项目中我们常常需要在修改状态时传值。比如上边的例子,是我们每次只加1,而现在我们要通过所传的值进行相加。其实我们只需要在Mutations里再加上一个参数,并在commit的时候传递就就可以了。我们来看具体代码:
const mutations={
add(state,n){
state.count+=n;
},
reduce(state){
state.count-=1;
}
}
通过dispatch一个action方法,通过action可以commit一个mutation来修改状态
在action中可以增加异步方法处理逻辑,例如:发送请求获取数据等。
mounted() {
// 派发action,获取floor组件的数据
this.$store.dispatch("getFloorList");
},
const state = {
// floor 组件的数据
floorList:[]
};
const mutations= {
GETFLOORLIST(state,floorList) {
state.floorList = floorList
}
};
const actions = {
// 获取floor数据
async getFloorList( { commit } ){
let result = await reqFloorList()
if(result.code === 200) {
// 提交mutation
commit("GETFLOORLIST",result.data)
}
}
};
有那几个辅助函数(4大金刚)
mapState,mapActions,mapMutations,mapGetters
vuex
中的数据和方法映射到vue组件
中。达到简化操作的目的<h3>{{cartList}}</h3>
import { mapGetters } from "vuex";
computed: {
...mapGetters(["cartList"])
}
const state = {
// 购物车列表数据
cartList: []
}
const getters = {
cartList(state) {
return state.cartList[0] || {}
},
}
<button @click="add">+</button>
//从Vue中引入mapMutations 函数
import { mapMutations } from "vuex";
//将需要的mutations函数,映射为当前组件的methods方法
methods: {
...mapMutations(["add"])
}
state: {
count: 0
},
mutations: {
add(state){
state.count++
}
}