var genAsyncTask2 = (val, time) => {
return () => {
return new Promise(function (resolve, reject) {
let timer = setTimeout(() => {
clearTimeout(timer);
resolve(val);
}, time);
});
}
}
// 任務隊列
var taskArr = [
genAsyncTask2('第1個異步任務,時間為2秒', 2000), genAsyncTask2('第2個異步任務,時間為1秒', 1000),
genAsyncTask2('第3個異步任務,時間為0.8秒', 800), genAsyncTask2('第4個異步任務,時間為2.5秒', 2500)
];
function *genFun(taskArr){
for(let i = 0 , len = taskArr.length; i < len; i++){
yield taskArr[i]().then(res => {
console.log('genSync', res);
return res;
});
}
}
/**
* 自動執行generate函數的next,並保證執行順序
* @param generateFn generate函數
* @param params 執行generate函數所需參數
*/
function generateAutoExec(generateFn, ...params) {
var g = generateFn(...params);
var next = function (res) {
if (res.done || typeof res.value == 'undefined') return res.value;
res.value.then((data) => {
console.log('data', data);
next(g.next(data));
}).catch((err) => {
console.error(err);
next(g.throw(err));
});
}
next(g.next());
}
generateAutoExec(genFun, taskArr);