gpt4 book ai didi

javascript - 上传前如何分割数据?

转载 作者:行者123 更新时间:2023-12-02 22:32:59 25 4
gpt4 key购买 nike

我有一个将数据上传到服务器的函数,我需要修改该函数以按 block 上传数据。

原始函数实现如下:

    private async updateDatasource(variableName: string, variableRecords: ChartDataResponse[]):Promise<boolean> {
// unrelated code
return this.portalService.updateDataForChart(variableId, variableRecords)
.then((updateRes: boolean) => {
if (updateRes) {
return this.executeRequest<HealthDataSource, boolean>({
path: `/variable/user/datasources/${dataSource.identifier}`,
method: 'PUT',
body: {
libelle: dataSource.datasource.libelle,
type: dataSource.datasource.type,
lastSyncDate: Math.max(maxDate, dataSource.datasource.lastSyncDate)
},
headers: this.getHeaders()
});
} else {
return false;
}
});
} else {
return Promise.reject(false);
}
}

我尝试了以下方法,但我似乎不知道如何返回带有结果的 promise :

    private async updateDatasource(variableName: string, variableRecords: ChartDataResponse[]): Promise<boolean> {
//unrelated code
//chunked the data
var chunks = _.chunk(variableRecords, 30);

return _.forEach(chunks, (chunk) => this.portalService.updateDataForChart(variableId, chunk))
.then((updateRes: boolean) => {
if (updateRes) {
return this.executeRequest<HealthDataSource, boolean>({
path: `/variable/user/datasources/${dataSource.identifier}`,
method: 'PUT',
body: {
libelle: dataSource.datasource.libelle,
type: dataSource.datasource.type,
lastSyncDate: Math.max(maxDate, dataSource.datasource.lastSyncDate)
},
headers: this.getHeaders()
});
} else {
return false;
}
});
} else {
return Promise.reject(false);
}
}

最佳答案

您可以使用 Promise.all() 获取 promise 结果列表

因此,在您的情况下,您希望生成 promise 数组,而不是使用 forEach 函数:

Promise.all(
chunks.map(chunk => this.portalService.updateDataForChart(variableId, chunk)))...
).then(results => {
// iterate over results array and do other stuff
})

关于javascript - 上传前如何分割数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58833014/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com