这篇文章主要讲解了“Vuex的属性实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vuex的属性实例分析”吧!
Vuex是专为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
简单来说:Vuex是Vue框架中状态管理

图中绿色虚线包裹起来的部分就是Vue的核心,state中保存的就是公共状态,改变state的唯一方式就是通过mutations进行更改
状态管理模式
把组件的共享状态抽取出来,以一个全局单例模式管理。在这种模式下,组件数构成了一个巨大的视图,不管在树的哪个位置,任何组件都能获取状态或者触发行为,这就是状态管理模式。
应用场景有:单页应用中,组件之间的数据状态
应用实例:
Vuex的属性
state
Vuex就是一个仓库,仓库里面放了很多对象,其中state就是数据源存放地,对应一般Vue对象里面的data
state里面存放的数据是响应式的,Vue组件从store中读取数据,若是store中的数据发生改变,依赖这个数据的组件也会发生更新
通过mapState把全局的state和getters映射到当前组件的computed计算属性中
getters
getters可以对state进行计算操作,它就是store的计算属性
虽然在组件内也可以做计算属性,但是getters可以在多组件之间复用
如果一个状态只在一个组件内使用,可以不用getters
Mutations
每个mutations都有一个字符串的事件类型(type)和一个回调函数(handler),这个回调函数就是实际进行状态修改的地方,并且它会接收state作为第一个参数:
const store = new Vuex.Store({
state:{
count:1
},
mutations:{
increment(state){
//变更状态
state.count++
}
}
})不能直接调用一个mutation handler。这个选项更像是事件注册,当触发一个类型为increment的mutations时,调用此函数。要唤醒一个mutation handler,需要调用相应的type调用store.commit方法
store.commit('increment')提交载荷(payload)
可以向store.commit传入额外的参数,即mutation的载荷(payload)
state:{
count:0
},
mutations:{
increment(state,n){
state.count += n
}
}
//组件
store.commit('increment',10)在大多数情况下,载荷应该是一个对象,这安样可以包含多个字段并且记录的mutation会更易读
state:{
count:0
},
mutations:{
increment(state,payload){
state.count += payload
}
}
//组件
store.commit('increment',{
amount:10
})Mutation需遵守Vue的响应规则
既然Vuex的store中的状态时响应式的,那么当我们变更状态时,监听状态的Vue组件也会自动更新。这也意味着Vuex中的mutation需要与使用Vue一样遵守一些注意事项:
最好提前在store中初始化好所有所需属性
当需要在对象上添加新属性时,应该
mutation必须是同步函数
使用Vue.set(obj,'newProp,123)
以新对象替换老对象。例如,利用对象展开运算符
state.obj = {...state.obj,newProp:123}actions
action类似于mutation,不同在于:
action通过store.dispatch方法触发
store.dispatch('increment')在action内部执行异步操作
actions:{
incrementAsync({commit}){
setTimeout(() => {
commit('increment')
},1000)
}
}action同样支持载荷方式和对象方式进行分发
//以载荷形式分发
store.dispatch('incrementAsync',{
amount:10
})
//以对象形式分发
store.dispatch({
type:'incrementAsync',
amount:10
})module
module可以让每个模块拥有自己的state、mutations、action、getters使得结构非常清晰,方便管理
const moduleA = {
state: { ... },
mutations: { ... },
actions: { ... },
getters: { ... }
}
const moduleB = {
state: { ... },
mutations: { ... },
actions: { ... }
}
const store = new Vuex.Store({
modules: {
a: moduleA,
b: moduleB
})使用Vuex的好处
感谢各位的阅读,以上就是“Vuex的属性实例分析”的内容了,经过本文的学习后,相信大家对Vuex的属性实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是天达云,小编将为大家推送更多相关知识点的文章,欢迎关注!