Vuex mapState设置状态

时间:2018-05-25 13:13:03

标签: vue.js vuejs2 vue-component vuex

在我的商店里,我有......

...
  addresses: [ /* array of address objects */ ],
  address: { /* holds chosen address */ }
...

在我的组件中,我有......

    import {mapState, mapActions} from 'vuex'

      export default {
        name: 'AddressBook',
        watch: {
          selectedAddress: function(newval) {
            // Update the address
            // address and addresses is mapped from the vuex store.
            this.address = Object.assign( this.address, this.addresses[newval]);
          }
        },
        data: {
          selectedAddress: 0 /* Address selected by index */
        }
        computed: {
          ...mapState(['addresses', 'address'])
        }
      }

地址和地址正在从vuex映射。 用户从选择的地址框中选择一个地址(例如地址[1])...用于更新地址。

让我感到困惑的是,以这种方式更新this.address只是有效......我的Vuex商店发生了变化。我以为我必须派遣/提交等..?这看起来太简单了..太容易了..

以这种方式在组件级别更新this.address是否安全?

1 个答案:

答案 0 :(得分:1)

  

以这种方式在组件级别更新this.address是否安全?

不,至少你应该从变异中提交变更(或者调用一个提交变异的动作)。来自Mutations documentation

  

在Vuex商店中实际更改状态的唯一方法是提交变异。

此外,您修改地址的方式可能不会发生在您的思考方式:

this.address = Object.assign( this.address, this.addresses[newval]);

它无意义(可能不可能?不确定Vue是否会冻结)无论如何都要重新分配这样的计算属性。实际发生的是Object.assign总是直接改变第一个参数。这就是为什么你可能经常看到空对象模式的原因,例如Object.assign({}, this.address, this.addresses[newval])

无论如何,为了避免像这样的细微意外突变,你可以启用strict mode,当发生那些不安全的突变时会发出警告。