参考代码
<script type="text/javascript"> const fn = (t) => { // 用setTimeout模拟异步请求 return new Promise((resolve, react) => { setTimeout(() => { console.log('任务完成', t, new Date()); resolve({ t, date: new Date() }); }, t * 1000); }) }; let arr = [1, 1, 1, 2, 2, 2, 3, 3, 3] /** * arrs 请求数据源数组 * limit 是每次并行发起多少个请求 * handleFn 就是异步处理函数 */ function limitQueueFn(arrs, limit, handleFn) { // 完成任务数 let runningIndex = 0; // 这是正在执行的下标 let finishedIndex = 0 // 这是已经执行完的下表 let result = new Array(arrs.length).fill(0) // 建立一个空数组, 存储结果 return new Promise((resolveFn, rejectFn) => { // 第一次的时候 一次性执行 limit 个任务 for (let i = 0; i < limit; i++) { run(); } // 执行一个任务 function run() { // 构造待执行任务 当该任务完成后 如果还有待完成的任务 继续执行任务 new Promise((resolve, reject) => { const value = arrs[runningIndex]; runningIndex++; // 这个是同步操作 resolve(handleFn(value)) }).then((res) => { result[finishedIndex] = res finishedIndex++ if (runningIndex < arrs.length) { run() } else { // 全部执行完毕 resolveFn(result) } }) } }) }; limitQueueFn(arr, 3, fn).then(res => { console.log('结果如下:') console.log(res) }) </script>
网友回复