Одним из решений, которое вы можете попробовать, является Webworkers . Если вы не использовали их раньше, они могут запускать сценарии в отдельном потоке, что позволяет вам использовать несколько ядер для обработки чего-либо. Они отлично подходят для распараллеливаемых задач, то есть задач, которые можно разбить без сбоев. Они вполне подойдут для вашего случая использования, поскольку вы просто делаете большую карту для ваших данных.
Прежде чем идти по этому пути, вы должны быть предупреждены о том, что у веб-работников есть некоторые накладные расходы. Чтобы получить данные для веб-работника, вы должны сериализовать их в поток, а затем десериализовать, когда они вернутся. Однако, если вы разделите свои задачи на отдельные работы и будете выполнять их параллельно, вы сможете смягчить некоторые из них.
// app.js
let largeArray = []; // contains the large amount of arrays to map
let outputArray = [];
while(largeArray.length){
let worker = new Worker('/path/to/worker/script.js');
worker.postMessage({
chunk: largeArray.splice(0,1000)
});
worker.onmessage = evt => {
let data = evt.data;
outputArray = outputArray.concat(data);
worker.terminate();
}
}
Отдельно есть рабочий сценарий, возможно, похожий на этот, доступный для ссылки.
// workerScript.js
self.onmessage = ({data: {chunk}}) => {
let final = chunk.map(u => ({
id: u.id,
name: u.name,
points: arr2.find(uu => uu.id === u.id)
}));
self.postMessage(final);
}
Вы можете спросить о сериализации, и это происходит автоматически. Веб-работники имеют собственную глобальную область видимости, и в результате сериализации вы можете отправлять объекты, массивы и примитивы. Все это можно сериализовать. Однако объекты с пользовательскими свойствами и классами будут выдавать ошибки. За кулисами это в основном берет ваши данные и делает JSON.stringify({{your data}})
, а затем в данных веб-работника становится результатом JSON.parse({{serialized data}})
.
Поскольку эта работа выполняется в отдельных потоках, вы не увидите каких-либо блокировок в главном потоке, где работает ваше приложение. Если вы попытаетесь обработать слишком много сразу, сериализация будет заметна, поскольку она блокируется до завершения.