av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - async/await 與 forEach 問題

瀏覽:115日期:2023-09-14 15:44:17

問題描述

方法一:沒問題

(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()

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产在线高清 | 欧美日韩成人在线观看 | 成人免费在线观看网站 | 水蜜桃一区二区 | 国产一区亚洲 | 九九热只有精品 | 久久在线免费视频 | 日韩视频免费大全中文字幕 | 一区二区视频在线播放 | 伊人久久中文字幕 | 天天草天天射 | 精品国产91乱码一区二区三区 | 亚洲精品乱码久久久久久蜜桃91 | 午夜影院福利 | 在线网站免费观看18 | 色av综合 | 中文字幕一区二区在线播放 | 欧美亚洲在线观看 | 日韩中文一区 | 簧片在线免费观看 | 日日拍夜夜拍 | av福利在线观看 | 欧美狠狠操 | h片免费看| 国产亚洲一区二区三区 | 爱爱免费小视频 | 日韩国产中文字幕 | 亚洲成人免费观看 | 国模一区二区 | 福利在线看 | 日韩一级大片 | 一区在线观看 | 国产区免费 | 特黄老太婆aa毛毛片 | 国产欧美久久久 | 日韩精品一区二区三区四区 | 高清一区二区三区 | 日皮视频在线观看 | 日韩天天操 | 国产一区二区影院 | 日韩精品在线一区二区 |