为什么要使用vuex:
整站有很多数据和状态,由很多组件拼成,组件间可能要共享一些状态,比如登录、注册部分每个页面都要有,数据要进行同步更新,状态很多的时候,通过事件触发也不切实际,所以出现了状态管理
vuex 是 Vue 配套的 公共数据管理工具,它可以把一些共享的数据,保存到 vuex 中,方便 整个程序中的任何组件直接获取或修改我们的公共数据
props、data和vuex的区别:
Vuex是为了保存组件之间共享数据而诞生的,如果组件之间有要共享的数据,可以直接挂载到vuex中,而不必通过父子组件之间传值了,如果组件的数据不需要共享,此时,这些不需要共享的私有数据,没有必要放到vuex中
只有共享的数据,才有权利放到vuex中
组件内部私有的数据,只要放到组件的data中即可
配置vuex的步骤:
安装vuex:
cnpm i vuex -S
导入包:
import Vuex from 'vuex'
注册vuex到vue中:
Vue.use(Vuex)
new Vuex.Store() 实例,得到一个 数据仓储对象
var store = new Vuex.Store({
state: {
},
mutations: {
},
getters: {
}
})
state:
可以把 state 想象成 组件中的 data ,专门用来存储数据的,如果在 组件中想要访问store 中的数据,只能通过 this.$store.state.*** 来访问
state: {
count: 0
},
mutations:
如果组件要操作 store 中的 state 值,只能通过调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据比如this.$store.state.count++,原因是万一多个组件因为操作store中的同一个state值导致了数据的紊乱,直接在组件内操作不能快速定位到错误的原因,因为每个组件都可能有不同的操作数据的方法,所以只能通过调用 mutations 提供的方法来操作 store 中的 state 值
如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')
mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
mutations: {
increment(state) {
state.count++
},
subtract(state, obj) {
console.log(obj)
state.count -= (obj.c + obj.d)
}
},
getters:
getters只负责 对外提供数据,不负责修改数据,如果想要修改 state 中的数据,要通过mutations
getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者
其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
getters: {
optCount: function (state) {
return '当前最新的count值是:' + state.count
}
}
将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据
const vm = new Vue({
el: '#app',
render: c => c(App),
store
})
在其他组件上面访问store中的数据
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">
</div>
</template>
<script>
export default {
data() {
return {
// count: 0
};
},
methods: {
add() {
// 千万不要这么用,不符合 vuex 的设计理念
// this.$store.state.count++;
this.$store.commit("increment");
},
remove() {
this.$store.commit("subtract", { c: 3, d: 1 });
}
},
computed:{
fullname: {
get(){},
set(){}
}
}
};
</script>
<style lang="scss" scoped>
</style>
amount.vue:
<template>
<div>
<!-- <h3>{{ $store.state.count }}</h3> -->
<h3>{{ $store.getters.optCount }}</h3>
</div>
</template>
<script>
</script>
<style lang="scss" scoped>
</style>