【问题标题】:Passing component's method's reference to action in Vuex将组件方法引用传递给 Vuex 中的操作
【发布时间】:2020-08-14 12:46:42
【问题描述】:

如果 vuex 操作进行的 API 调用失败,我正在寻找一种方法来更改组件内的某些数据值。目前,我通过在我的操作中添加一个 try-catch 并抛出错误,然后使用另一个 try-catch 在组件内捕获错误来做到这一点。像这样的:

组件 1

async method() {
 try {
    this.VUEX_ACTION();
 }
  catch (e) {
    /* this method changes the values inside data */
    this.componenntMethodToExecute();
 }
}

Vuex

VUEX_ACTION() {
 try {
   API_CALL()
 }
 catch (e) {
   throw e;
 }
}

这种方法的问题在于,我必须一次又一次地将所有存储操作调用包装在 try-catch 中的组件中。我发现的一种解决方案是订阅 Vuex 中的操作/突变,并相应地更改组件内的数据。但这又涉及在组件中添加订阅者。

此外,我无法将组件的所有数据值保留在 Vuex 中,因为我在组件中使用/更改了很多数据值,并且将它们移动到 Vuex 需要有自己的操作/突变。

我尝试完成工作的另一种方法是通过将函数的“this”上下文绑定到当前组件,将一个函数从组件传递到 Vuex。此函数更改我想要更改的数据值。它完成了我的工作,但 我不确定将函数的引用传递给 vuex 是否是一个好习惯。您能否提出一个更好的解决方案,或者这是解决问题的方法?

【问题讨论】:

  • “我必须一次又一次地将我所有的 API 调用包装在 try-catch 中” ????为什么这是个问题?
  • 应该是“将我所有的动作包装在 try-catch 中的组件中”。我会更新问题。

标签: javascript vue.js vuex


【解决方案1】:

我不确定我是否正确理解了您的问题。你在寻找这样的东西吗?

Vuex:

VUEX_STATE: {
    e: {}
}
VUEX_MUTATIONS: {
    e: (state, e) => state.e = e
}
VUEX_GETTERS: {
    error: state => state.e
}
VUEX_ACTIONs: {
    apiCall({ commit }) {
        try {
            API_CALL()
        }
        catch (e) {
            commit('e', e)
        }
    }
}

Vue 组件scriptsmapGetters(['error']) 只需要包含在要显示错误的组件中。 mapGetters(['apiCall']) 只需要包含在要调用 vuex 操作的组件中即可。

computed: {
    ...mapGetters([
        'error'
    ]),
    changeDataValueHere() return this.error ? 'changed' : 'value if no error from api call',
    altChangedDataValuesHere() return this.error ? {a: 'changed', b: 'changed' ...} : {a: 'unchanged', b: 'unchanged' ...}
},
methods: {
    ...mapActions([
        'apiCall'
    ])
    apiAction() {
        this.apiCall
    }
}

这样,组件中就不需要 try-catch 块了。

【讨论】:

  • 不完全是。假设组件中有 3-4 个数据值。当 API 调用失败时,我必须在我的组件中更改这 3-4 个值。我不能将这些数据值保存在 vuex 中,因为这意味着要处理它们的变化的突变/动作。
  • @t k “另外,我不能将组件的所有数据值都保存到 Vuex,因为这意味着要多次调用动作/突变。”
  • 更新了我的答案。您可以使用 computed 值而不是 data 值,这些值将根据 apiCall 的结果而有所不同
  • 对于数据中的 3-4 个值,这意味着有很多计算属性。不要认为这是一个好的解决方案
  • 您能否编辑您的问题以包含更具体针对您的问题的代码?您使用computed 而不是 data - 所以最终会得到 3-4 个更多的计算值和 3-4 个更少的数据值。您还可以返回一个包含 3-4 个属性的对象。
猜你喜欢
  • 2019-06-14
  • 2021-12-23
  • 1970-01-01
  • 2017-01-31
  • 2019-11-11
  • 2019-04-20
  • 2014-07-04
  • 1970-01-01
  • 2020-09-28
相关资源
最近更新 更多