store踩坑

某个方法里面写的是:

getCenter (index, center) {
  let listTemp = this.$store.state.list
  listTemp[index] = center
  this.$store.commit('UPDATE_list', listTemp)
}

结果在另一个组件监听这个变量的时候,却发现在watch中监听不到,但是已经进入store并且store里面的值是发生变化了的。

getCenter (index, center) {
  let listTemp = this.list.slice(0) // 返回新的数组
  listTemp[index] = center
  this.$store.commit('UPDATE_list', listTemp)
}

这样解决了问题,猜测是因为同一个引用,对于引用对象,watch监听的应该是内存地址的变化

后面使用了另一种赋值方式

listTemp.splice(index, 1, center)

这样子在watch中也能监听到变化,但是数组的索引赋值却不行,是因为Vue的watch没有对数组的索引改变进行监听

发布了51 篇原创文章 · 获赞 33 · 访问量 9万+

猜你喜欢

转载自blog.csdn.net/shelbyandfxj/article/details/102731254