久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - async/await 與 forEach 問題

瀏覽:127日期: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 聲明的函數(shù)上下文中. 如下 forEach 中, 是不能直接使用await的.

let array = [0,1,2,3,4,5];(async ()=>{ array.forEach(function(item){ console.log(item); await wait(1000);//這是錯(cuò)誤的寫法 });})();//因await只能用于 async 聲明的函數(shù)上下文中, 故不能寫在forEach內(nèi).下面我們來看正確的寫法(async ()=>{ for(let i=0,len=array.length;i<len;i++){ console.log(array[i]); await wait(1000); }})();

仔細(xì)看下,發(fā)現(xiàn)你的問題是另外一種情況。你這樣把test當(dāng)做回調(diào)函數(shù)傳入進(jìn)去,sleep方法是同步執(zhí)行的,await還是生效的,只是同時(shí)生效。因此后續(xù)函數(shù)在等待相同的時(shí)間后,一起執(zhí)行。

回答2:

async 做異步循環(huán)的時(shí)候最好用 for ... of ... 或者 Promise.all()

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 满城县| 汉源县| 宁城县| 宜黄县| 江达县| 两当县| 绥阳县| 营山县| 崇阳县| 遂溪县| 克山县| 宁陕县| 临颍县| 尖扎县| 确山县| 新竹市| 咸宁市| 礼泉县| 庄河市| 楚雄市| 赣州市| 雷山县| 开阳县| 榆社县| 徐州市| 浮梁县| 安庆市| 简阳市| 祁东县| 寻乌县| 宁都县| 高清| 大田县| 进贤县| 尼勒克县| 南雄市| 西乌珠穆沁旗| 利津县| 峨边| 泰和县| 金昌市|