我一直遇到有关 JS promise 使用的问题,希望这只是我遗漏了一些非常明显的东西。
本质上,我尝试一次读取多个 JSON 文件并将它们的内容推送到属于另一个对象的数组,然后对该数组上的元素执行操作。因此,在尝试对其进行操作之前需要填充数组。然而,尽管我在理论上使用 promises 来确保顺序是正确的,但我所写的似乎无法做到这一点。
我该如何解决这个问题?
以下是我正在使用的代码片段,其中出现了问题:
这是我将提取的对象推送到我的数组的函数:
function pushNewRoom (ship, name_json_folder, elem, id) {
lt promiseRoom = new Promise ((resolve, reject) => {
let newRoom = gf.getJSONFile(name_json_folder + '/' + elem + ".json")
// note: getJSONFile allows me to grab a JSON object from a file
.then(
(data) => {
data.name = elem;
ship.rooms.push(data);
return data;
}).then((newRoom) => {
resolve(newRoom);
}).catch((reject) => { // if the JSON file doesn't exist a default object is generated
let newRoom = new Room (elem, id);
ship.rooms.push(newRoom);
resolve(newRoom);
});
});
return promiseRoom;
}
这是调用该函数并执行我之后需要的操作的部分:
exports.generateRoomsByLayout = function (name_json_folder, ship)
{
ship.rooms = [];
console.log("reached step 1");
// First execution step: get a JSON file
gf.getJSONFile(name_json_folder + "/_base_layout.json")
.then(function (shipmode){
// Note: shipmode is a JSON object that acts as a blueprint for the operations to follow.
// Importantly here, it contains an array, layout, containing the names of every other JSON file I will need to perform the operations.
console.log("reached step 2");
}).catch((err) => {
});
});
};
这个问题就发生在 Promise.allSettled() 行。程序没有等待 ship.layout.map() 生成的 promise,它会变成一个可迭代的数组,而是继续执行。
我想这是因为 Promise.allSettled() 没有等待 map() 生成数组才继续前进,但一直无法解决问题,并且仍然怀疑这是解释。谁能告诉我我在这里做错了什么?
如果我问的不清楚,请告诉我,我会尽力澄清。
编辑:我怀疑它链接到 Promise.allSettled() 而不是等到 map() 填充数组以考虑数组内的每个承诺都已解决,因为它的长度在第 3 步似乎为 0,但我不确定。
慕尼黑8549860
相关分类