Vue.js-在更新异步计算属性后更新计算属性

时间:2019-01-25 00:17:41

标签: asynchronous vue.js vuejs2 computed-properties

我有一个计算属性(filteredSyms),该属性取决于异步计算属性(allSynonyms)。我为此使用异步计算插件: https://www.npmjs.com/package/vue-async-computed

但是,当数据得到更新时,计算属性不会等到异步属性更新的结果。因此,我收到的不是最新信息。然后,在异步属性实际返回新值之后,计算属性不会再次运行update。

如何使其以计算机属性等待直到异步计算属性产生结果的方式工作?

代码如下:

asyncComputed: {
  async allSynonyms() {
    let allSyns = await this.$axios.$post('/db/sym/synonyms', this.model.syms);
    return allSyns;
  }
},

computed: {
  filteredSyms() {

    let that = this;
    let allSyn = this.allSynonyms;

    let exactMatch = this.symsByRating.filter(
      function (v) {
        let isExactMatch = v.title.toLocaleLowerCase().indexOf(that.searchString.toLocaleLowerCase()) >= 0;

        return !that.idsToFilter.includes(v.id) && isExactMatch
          && (!that.currentBodyPart || v.bodyParts.indexOf(that.currentBodyPart) >= 0)
          && that.hasMoreSubsyms(v)
          && (!allSyn || !that.containsObject(v, allSyn))
          && (v.sex == that.model.sex || v.sex == 'NA');
      });

    let partialList = [];

    exactMatch.forEach(ex => partialList.push({n: 100, sym: ex}));

    for (let sym of this.symsByRating ) {

      let searchWords = this.searchString.toLocaleLowerCase().split(' ');
      let symWords = sym.title.toLocaleLowerCase().split(' ');

      let n = 0;
      let isPartialMatch = false;
      symLoop:for (let symWord of symWords) {
        symWord = symWord.substring(0, symWord.length - 1);
        for (let searchWord of searchWords) {

          // don't count last letters of the words
          searchWord = searchWord.substring(0, searchWord.length - 1);

          if (searchWord.length > 2 && symWord.indexOf(searchWord) >= 0) {
            n++;
            isPartialMatch = true;
          }
        }
      }

      if (exactMatch.indexOf(sym) < 0 && isPartialMatch
        && (!this.currentBodyPart || sym.bodyParts.indexOf(this.currentBodyPart) >= 0)
        && this.hasMoreSubsyms(sym)
        && (!allSyn || !this.containsObject(sym, allSyn))
        && (sym.sex == that.model.sex || sym.sex == 'NA')) {

        partialList.push({n: n, sym: sym});

      }
    }

    partialList.sort(function(obj1, obj2) {
      return obj2.n - obj1.n;
    });

    if (this.searchString && this.searchString != '') {
      partialList = this.filterSynonyms(partialList);
    }

    let fs = partialList.map(ws => ws.sym);

    console.dir(fs);

    return fs;

  }
}

filtered方法上有很多东西,但是我想这里的重点是它使用this.allSynonyms进行检查,但是在执行filteredSyms时不会更新。

感谢您的建议!

1 个答案:

答案 0 :(得分:1)

(我还没有真正测试过,但是应该可以。)

vue-async-computed确实提供了this.$asyncComputed.allSynonyms.success中的状态。

尝试将this.$asyncComputed.allSynonyms.success作为依赖项添加到filteredSyms,并且在成功状态更改时应该更新。