vuex的核心概念:
组建中访问State中数据的第一种方式:
this.$store.state.全局数据名称
组件访问State中数据的第二种方式:
从vuex中按需导入mapState函数
import {{mapState}} from 'vuex'
通过导入的mapState函数,将当前组件需要的全局数据,映射为当前组价的computed计算属性:
//2.将全局数据,映射为当前组件的计算属性
computed: {
...mapState({
'count'
})
}
1.只能通过mutation变更Store的数据 ,不可以直接操作Store中的数据
2.通过这种方式虽然操作起来稍微繁琐一些,但是可以集中监控所有数据的变化。
mutition的使用
//定义Mutation
const store = new Vuex.Store({
state: {
count: 1
},
mutations: {
add(state) {
//变更状态
state.count++
}
}
})
如何在组建中调用mutations中的函数
methods: {
handlel() {
//触发mutations的第一种方式
this.$store.commit('add')
}
}
如何在调用mutations时传递参数
//定义Mutation
const store = new Vuex.Store({
state: {
count: 1
},
mutations: {
addN(state,step) {
//变更状态
state.count+=step
}
}
})
组件如何传递参数:
commit作用就是调用某个mutations函数
methods: {
handle2() {
this.$store.commit('addN',4)
}
}
触发mutations的第二种方式
//首先,需要从vuex中按需导入mapMutations函数
import {mapMutations} from 'vuex'
store:
mutations: {
//count减一
sub(state) {
state.count--
},
}
使用mapMutations调用mutations中的函数,在定义一个函数调用该函数
methods: {
...mapMutations(['sub']),
btnSub() {
this.sub()
}
}
传参:
mutations: {
//count减N
subN(state,step) {
state.count-=step
},
}
组件中使用
methods: {
...mapMutations(['subN']),
btnSub1() {
this.subN(5)
}
}
注意:不要在Mutations中执行异步操作
如果 通过异步操作变更数据,必须通过Action,而不能只用Mutation,但是在Action中还要通过触发Mutations的方式变更数据。Mutations中只允许写同步的代码
const store = new Vuex.Store({
mutations: {
add(state) {
state.count++
}
},
//在actions中,不能直接修改state中的数据;
//必须通过context.commit() 触发某个mutations才行
actions: {
addAsync(context) {
setTimeout(() =>{
context.commit('add')
},1000)
}
}
})
触发Action的方式一
methods: {
handle() {
//这里的dispatch函数,专门用来触发action
this.$store.dispatch('addAsync')
}
}
触发actions异步任务时携带参数:
actions: {
addNAsync(context,step){
setTimeout(() =>{
context.commit('addN',step)//这里调用的addN是mutations内的
},1000)
}
}
组件使用
btnHandler4() {
this.$store.dispatch('addNAsync',5)
}
触发Action的方式二
this.$store.dispatch()是触发actions的方式一,方式二为:需要导入mapActions函数
import {mapActions} from 'vuex'
在actions中定义一个异步的函数
actions: {
subAsync(context) {
setTimeout(() =>{
context.commit('sub')//sub是mutations中的
},1000)
}
}
组件使用
import {mapState,mapMutations,mapActions} from 'vuex'
methods: {
...mapActions(['subAsync']),
btnSub2() {
this.subAsync()
}
}
携带参数
在actions中定义函数
subNAsync(context,step) {
setTimeout(() => {
context.commit('subN',step)
},1000)
}
页面使用,同样也需要导入mapActions
import {mapState,mapMutations,mapActions} from 'vuex'
methods: {
...mapActions(['subAsync',"subNAsync"]),
btnSub3() {
this.subNAsync(8)
}
}
//定义Getter
const store = new Vuex.Store({
state: {
count:0
},
getters: {
showNum(state) {
return '当前最新的数量为【'+ this.state.count+'】'
},
}
}
})
使用getter的第一种方式:
this.$store.getters.名称
使用方式二:
同样需要导入mapGetters
{{showNum}}
import {mapGetters} from 'vuex'
computed: {
...mapGetters(['showNum'])
},