vuex(mapActions+mapGetter)配合v-model处理数据

业务场景:
elementui中的el-checkbox绑定的数据为一个存储在vuex当中的数据

// template
<el-checkbox v-model="showBasicData"></el-checkbox>

一开始,本来尝试直接用mapGetters中返回的getter作为数据源,类似如下形式:

computed: {
	...mapGetters([
		'showBasicData'
	])
}

但,会报错:
Computed property “XX” was assigned to but it has no setter.
原因:
v-model是双向绑定,而mapGetter中的showBasicData是单项数据流,只有getter,没有setter,故需要改写为以下形式:

computed: {
	...mapGetters([
		'showBasic'
	]),
	showBasicData: {
		get() {
			return this.showBasic
		},
		set() {
			this.resetBasic() // 这里的操作为对vuex中的action的调用
		}
	}
}

接下来,看下resetBasic这个函数怎么通过mapActions获取到:

methods: {
	...mapActions({
		resetBasic: 'user/resetBasic' // 这一步一定记得要加上module在action方法名前,不然无法获取到action
	})
}

这样,就可以正常获取到action,并可以将vuex中的数据用于v-model。

…mapActions及…mapGetters基本使用(Vuex官网):

https://vuex.vuejs.org/zh/guide/actions.html
https://vuex.vuejs.org/zh/guide/getters.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值