从品牌网站建设到网络营销策划,从策略到执行的一站式服务
今天小编给大家分享一下vuex中如何利用state监听数组变化的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
成都创新互联专业为企业提供天河网站建设、天河做网站、天河网站设计、天河网站制作等企业网站建设、网页设计与制作、天河企业网站模板建站服务,十多年天河做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const state = { messArray:[] } const mutations = { modifyArray(state, obj){ state.messArray=obj.messArray // Vue.$set(this,this.messArray,[...obj.messArray]) } const actions={ modifyArr(context,obj){ context.commit('modifyArray',obj) }, } export default new Vuex.Store({ state, mutations, actions })
然后在组建的data中,通过mapState映射过去:
//在使用事前必须引入这个 import { mapState, mapGetters, mapMutations, mapActions } from 'vuex' data() { return { ...mapState(["messArray"]), } }
然后在watch中设置了监听:
watch:{ messArray: function(val){ console.log("watch ChildA.vue "+val) } }
这个时候问题就出来了,虽然数组修改了,但是watch就是监听不到。
解决办法
在我搜索了一些网上的办法之后,发现大部分我都用不来,最后只能巧妙的通过computed和getter解决了这个问题。
给刚才的store.js添加一个getter
const getters = { messArray_get:state=>state.messArray, }
然后在要监听变化的组件中的computed中添加如下代码:
...mapGetters(['messArray_get']),
然后在watch中这样写
watch:{ messArray_get : function(val){ console.log("messArray_get "+val) } }
以上就是“vuex中如何利用state监听数组变化”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注创新互联行业资讯频道。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图