首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TABULATOR不显示数据的Mutator

TABULATOR不显示数据的Mutator
EN

Stack Overflow用户
提问于 2020-02-20 03:47:28
回答 2查看 205关注 0票数 1

我有一个不能显示数据的赋值函数的问题。我有五列从AJAX URL获取数据(这些都很好用),还有第六列,我打算用FETCH从另一个URL获取数据,并用一个mutator显示数据。下面是获取数据的代码:

代码语言:javascript
复制
const comtot = async function (value, data) {
    let response = await fetch(API_TOT);
    let com = await response.json();

    console.log(com[0].total);
    return com[0].total;
} 

下面是带有赋值函数的列的代码:

代码语言:javascript
复制
{
    title: "Cantidad de Compras",
    field: "total",
    align: "center",
    sorter: "number",
    headerFilter: "input",
    mutator: comtot().then((res) => {
        console.log(res);
        return res
    })     
}

我已经尝试使用promises而不是ASYNC AWAIT,并得到了相同的结果。此外,我还尝试升级到4.5.3版本,因为我在另一个帖子上看到了与我的问题非常相似的版本,也不起作用。我可能会补充说,我可以将数据记录到控制台,但不能将其显示到表中。我做错了什么?

EN

回答 2

Stack Overflow用户

发布于 2020-04-10 22:40:55

Tabulator中的转换器是同步的,它们会立即返回,因此在加载表数据之前,表不必等待数千个承诺来解析,因为这会极大地增加表加载时间。

这意味着您不能在赋值函数中使用诸如promises或await语句之类的异步代码。

正确的方法是在将数据加载到表中之前进行所有这些调用,然后使用setData函数加载完成的数据集

票数 1
EN

Stack Overflow用户

发布于 2020-03-12 10:03:45

*这是我发布的另一个问题的相同答案。我不知道我的代码出了什么问题,所以我发布了两个不同的问题,这两个问题我认为是无关的,但我错了。

我弄清楚了,问题是在Tabulator中,表中的mutator从另一个源获取数据,而不是从表的其余部分获取数据,所以当mutator开始工作时,表已经构建好了,我发现mutator在触发时需要尽快获得数据,但它的源数据还没有准备好,所以我所做的是使用:

代码语言:javascript
复制
function delayIt() {table.setData(API_URL)}
setTimeout(delayIt, 1000)

因此,在构建表时,来自mutator源的数据已经可用,所以当启动mutator时,一切工作正常。如果这让人困惑,我很抱歉,我不知道如何用其他方式解释。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60308106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档