vue项目引入全局vuex
Vuex 是一个全局的共享数据存储区域,相当于一个数据的仓库,Vuex是为了保存组件之间共享数据而诞生的,如果组件之间有要共享的数据,可以直接挂载到vuex中,而不必通过父子组件之间传值了,如果组件的数据不需要共享,就不必放到vuex中;只有共享的数据。配置vuex可有如下五个步骤运行 cnpm i vuex -S导入包注册vuex到vue中new Vuex.Store() 实例,得...
Vuex 是一个全局的共享数据存储区域,相当于一个数据的仓库,Vuex是为了保存组件之间共享数据而诞生的,如果组件之间有要共享的数据,可以直接挂载到vuex中,而不必通过父子组件之间传值了,如果组件的数据不需要共享,就不必放到vuex中;只有共享的数据,才保存到vuex中。
配置vuex可有如下五个步骤
- 运行 cnpm i vuex -S
- 导入包
- 注册vuex到vue中
- new Vuex.Store() 实例,得到一个 数据仓储对象
- 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据
本例如下:
在src 文件夹下创建文件夹store及在store文件夹下创建store.js,及 目录: src/store/store.js
如图所示:
store.js代码如下:
// 入口文件
import Vue from 'vue'
// 配置vuex的步骤
// 1. 运行 cnpm i vuex -S
// 2. 导入包
import Vuex from 'vuex'
// 3. 注册vuex到vue中
Vue.use(Vuex)
// 4. new Vuex.Store() 实例,得到一个 数据仓储对象
const store = new Vuex.Store({
state: {
// 大家可以把 state 想象成 组件中的 data ,专门用来存储数据的
// 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问
count: 0
},
mutations: {
// 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
increment(state) {
state.count++
},
// 注意: 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')
// 这种 调用 mutations 方法的格式,和 this.$emit('父组件中方法名')
subtract(state, obj) {
// 注意: mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
console.log(obj)
state.count -= (obj.c + obj.d)
}
},
getters: {
// 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations
optCount: function (state) {
return '当前最新的count值是:' + state.count
}
// 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;
// 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
}
})
export default store
第五个步骤如下:
在项目的入口文件中(main.js)引入store.js并挂载到vue中,如下图所示
总结:
- state中的数据,不能直接修改,如果想要修改,必须通过 mutations
- 如果组件想要直接 从 state 上获取数据: 需要 this.$store.state.***
- 如果 组件,想要修改数据,必须使用 mutations 提供的方法,需要通过 this.$store.commit(‘方法的名称’, 唯一的一个参数)
- 如果 store 中 state 上的数据, 在对外提供的时候,需要做一层包装,那么 ,推荐使用 getters, 如果需要使用 getters ,则用 this.$store.getters.***
使用vuex案例如下:
本组件 counter.vue代码如下
<template>
<div>
<input type="button" value="减少" @click="remove">
<input type="button" value="增加" @click="add">
<br>
<input type="text" v-model="$store.state.count">
<h3>{{ $store.getters.optCount }}</h3>
</div>
</template>
<script>
export default {
data() {
return {
// count: 0
};
},
methods: {
add() {
// this.$store.state.count++; // 注意:不要这么用,不符合 vuex 的设计理念
this.$store.commit("increment");
},
remove() {
this.$store.commit("subtract", { c: 1, d: 1 });
}
},
computed:{
}
};
</script>
<style scoped>
</style>
在其他组件中使用$store.state.count 或 s t o r e . g e t t e r s . o p t C o u n t 即 可 获 取 到 v u e x 保 存 的 c o u n t 变 量 , store.getters.optCount 即可获取到vuex保存的count变量, store.getters.optCount即可获取到vuex保存的count变量,store.getters.optCount 中可以从上面的store.js中查看。
更多推荐
所有评论(0)