checkbox与data和checkbox自动双向绑定?

在页面操作的过程中并没有涉及到store中的数据,为什么会被影响呢??
为什么在updated中打印的2项总是相等?
使用chrome的vue插件,可以在vuex界面明确看到触发updated中的打印后,store中的channelsOn并未改变,为什么打印出的结果却是已经改变了?
本意是使用data暂存本页数据,退出页面时比对data与store中的原数据是否相等,再进一步操作

<label v-for="(channel, index) in channels" :key="index">
    <input type="checkbox" class="canshu-input canshu-checkbox" 
    :checked="status.channelsOn.indexOf(channel.id)>=0"
      @click='checkedOne(channel.id)'>
           &nbsp;{{channel.txt}}
</label>

js:

updated(){
  console.log(this.status.channelsOn);
  console.log(this.$store.state.canshu.status.channelsOn);
},
methods: {    //不重要吧
  checkedOne(eleId) {
    let idIndex = this.status.channelsOn.indexOf(eleId)
    if (idIndex >= 0) {
      this.status.channelsOn.splice(idIndex, 1)
    } else {
      this.status.channelsOn.push(eleId)
    }
  }
},
data() {
  return {
    status: {
      channelsOn: this.$store.state.canshu.status.channelsOn
    },
    channels: [    //不重要
      { id: '1', txt: '通道1'},
      { id: '2',txt: '通道2'},
      {id: '3',txt: '通道3' },
      {id: '4',txt: '通道4'},
    ]
  }
}
阅读 3.9k
2 个回答

此值非彼值,你只是把store里面的值给了你组件的data,后续改变的也只是data的值
了解更多参考一下vuex的文档吧

应用层级的状态应该集中到单个 store 对象中。

提交 mutation 是更改状态的唯一方法,并且这个过程是同步的。

异步逻辑都应该封装到 action 里面。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题