javascript - async/await 與 forEach 問題
問題描述
方法一:沒問題
(async function () {for (let i = 0; i < triggerArr.length; ++i) { await sleep(); triggerArr[i]();} })();
方法二:是一起輸出來的,為什么?(沒有等待)
const test = async function (item) { await sleep(); item(); }; triggerArr.forEach(test);
全部的代碼
function signalLamp(singalArr) { function tic(sign, delay) {return () => new Promise((res, rej) => { setTimeout(() => {res();console.log(sign); }, delay || 1000);}); } const rawArr = singalArr.slice(); const triggerArr = rawArr.reduce(function (prev, item) {return prev.concat([tic(item, 1000)]); }, []); const sleep = () => new Promise((res, rej) => setTimeout(res, 1000)); /* Method 1 */ (async function () {for (let i = 0; i < triggerArr.length; ++i) { await sleep(); triggerArr[i]();} })(); /* Method 2 */ // const test = async function (item) { // await sleep(); // item(); // }; // triggerArr.forEach(test);}signalLamp([’red’, ’green’, ’yellow’]);
問題解答
回答1:我給你講下。await 只能用于 async 聲明的函數上下文中. 如下 forEach 中, 是不能直接使用await的.
let array = [0,1,2,3,4,5];(async ()=>{ array.forEach(function(item){ console.log(item); await wait(1000);//這是錯誤的寫法 });})();//因await只能用于 async 聲明的函數上下文中, 故不能寫在forEach內.下面我們來看正確的寫法(async ()=>{ for(let i=0,len=array.length;i<len;i++){ console.log(array[i]); await wait(1000); }})();
仔細看下,發現你的問題是另外一種情況。你這樣把test當做回調函數傳入進去,sleep方法是同步執行的,await還是生效的,只是同時生效。因此后續函數在等待相同的時間后,一起執行。
回答2:async 做異步循環的時候最好用 for ... of ... 或者 Promise.all()
相關文章:
1. javascript - vscode alt+shift+f 格式化js代碼,通不過eslint的代碼風格檢查怎么辦。。。2. javascript - [js]為什么畫布里不出現圖片呢?在線等3. python - 如何判斷爬蟲已經成功登陸?4. html - vue項目中用到了elementUI問題5. html5 - 有可以一次性把所有 css外部樣式轉為html標簽內style=" "的方法嗎?6. javascript - 如何將一個div始終固定在某個位置;無論屏幕和分辨率怎么變化;div位置始終不變7. javascript - 原生canvas中如何獲取到觸摸事件的canvas內坐標?8. javascript - 有什么比較好的網頁版shell前端組件?9. javascript - 這不是對象字面量函數嗎?為什么要new初始化?10. javascript - 求解答:實例對象調用constructor,此時constructor內的this的指向?
