Vuex如何实现数据共享
Vuex如何实现数据共享
·
一、概念:
在Vue中实现集中式状态(数据)管理的一个Vue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。当多个组件需要数据共享的时候,我们就可以使用Vuex。
二、使用Vuex统一管理的好处:
- 能够在vuex中集中管理共享数据,易于后期开发和维护
- 能够高高效的实现组件之间的共享,提高开发效率
- 存储在vuex中都是响应式的能够实时保护,数据与页面的同步
三、环境搭建:
1、安装vuex
npm
npm install vuex --save
2、引用vuex
import Vue from 'vue'
import Vuex from 'vuex'
//vuex为插件,vue中使用vuex用vue.use()
Vue.use(Vuex)
3、创建js文件
//准备actions对象——响应组件中用户的动作
const actions = {}
//准备mutations对象——修改state中的数据
const mutations = {}
//准备state对象——保存具体的数据
const state = {}
//创建并暴露store
export default new Vuex.Store({
actions,
mutations,
state
})
4、在main.js中引入该文件
......
//引入store
import store from './store'
......
//创建vm
new Vue({
el:'#app',
render: h => h(App),
store
})
四、如何使用?
1、初始化数据,配置actions,配置mutations,操作文件store.js
const actions = {
//响应组件中加的动作
jia(context,value){
context.commit('JIA',value)
},
}
const mutations = {
//执行加操作
JIA(state,value){
state.sum += value
}
}
2、组件中修改vuex中的数据
$store.dispatch('action中的方法名',数据)
$store.commit('mutations中的方法名',数据)
3、在store.js中追加getters配置
const getters = {
bigSum(state){
return state.sum * 6
}
}
4、mapState方法:用于帮助我们映射state中的数据为计算属性
computed: {
//借助mapState生成计算属性:sum、school、subject(对象写法)
...mapState({sum:'sum',school:'school',subject:'subject'}),
//借助mapState生成计算属性:sum、school、subject(数组写法)
...mapState(['sum','school','subject']),
},
5、mapGetters方法:用于帮助我们映射getters中的数据为计算属性
computed: {
//借助mapGetters生成计算属性:bigSum(对象写法)
...mapGetters({bigSum:'bigSum'}),
//借助mapGetters生成计算属性:bigSum(数组写法)
...mapGetters(['bigSum'])
},
6、mapActions方法:用于帮助我们生成与actions对话的方法
methods:{
//靠mapActions生成:incrementOdd、incrementWait(对象形式)
...mapActions({incrementOdd:'jiaOdd',incrementWait:'jiaWait'})
//注意:如果要带value值传递的话,值要添加在形参里面,sum(value)、school(value)
//靠mapActions生成:incrementOdd、incrementWait(数组形式)
...mapActions(['jiaOdd','jiaWait'])
}
7、mapMutations方法:用于帮助我们生成与mutations对话的方法
methods:{
//靠mapActions生成:increment、decrement(对象形式)
...mapMutations({increment:'JIA',decrement:'JIAN'}),
//靠mapMutations生成:JIA、JIAN(对象形式)
...mapMutations(['JIA','JIAN']),
}
更多推荐
已为社区贡献1条内容
所有评论(0)