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

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

JavaScript sleep睡眠函數的使用

瀏覽:85日期:2023-09-28 09:43:41
目錄1.sleep函數2. setTimeout3.Promise 4. async await5. 1s后輸出1 2s后輸出2 3s后輸出3參考文章:1.sleep函數

JavaScript是單線程運行的,沒有內置的sleep函數,現在模擬實現sleep延遲執行的效果。

使用睡眠函數實現紅綠燈代碼,紅燈2秒,黃燈1秒,綠燈3秒,循環改變顏色。

2. setTimeout

直接使用setTimeout實現sleep()的方法,兼容性最好,但是使用了回調函數的實現方式,代碼的可讀性和維護性不是很好。

// setTimeoutlet fun = () => console.log(’time out’);let sleep = function(fun,time){ setTimeout(()=>{ fun(); },time);}sleep(fun,2000);setTimeoutsetTimeout是最基本的實現方式,代碼如下,使用遞歸來實現循環改變顏色:function changeColor(color) { console.log(’traffic-light ’, color);}function main() { changeColor(’red’); setTimeout(()=>{ changeColor(’yellow’); setTimeout(() => { changeColor(’green’); setTimeout(main, 2000); }, 1000); }, 2000);}main();3.Promise

在ES6的語法中,Promise是sleep方法異步的實現一種方式,借助Promise方法可以優雅的構建sleep實現方法,避免了使用函數回調的使用方式。

// promiselet fun = () => console.log(’time out’);let sleep2= (time)=> new Promise((resolve)=>{ setTimeout(resolve,time)})sleep2(2000).then(fun);

Promise

使用Promise,把下一次的顏色改變寫在then里面,最后同樣使用遞歸完成循環。

使用promise代替setTimeout,利用鏈式調用以及then來實現燈的轉換,then返回一個promise對象,當這個對象為resolve狀態then可以持續調用。

const traffic_light=(color,duration)=>{ return new Promise((resolve,reject)=>{ console.log(’traffic-light ’, color); setTimeout(()=>{resolve() },duration) })}const main=()=>{ Promise.resolve() .then(()=>{return traffic_light(’red’,3000) }) .then(()=>{return traffic_light(’yellow’,1000) }) .then(()=>{return traffic_light(’green’,2000) }) .then(()=>{main(); })}main()4. async await

async await實際上是generator和promise的語法糖,在提供同步編程方式實現異步調用的基礎上,同時滿足對sleep函數語義化的支持,也是常用的sleep的實現方式。

// async awaitasync function wait(time){ await sleep2(time); fun();}wait(3000);

async await 使用

使用async await就可以避免Promise的一連串.then.then.then,也不再需要遞歸,使用while(true)就可以實現循環。

function sleep(duration) { return new Promise(resolve => { setTimeout(resolve, duration); })}async function changeColor(color, duration) { console.log(’traffic-light ’, color); await sleep(duration);}async function main() { while (true) { await changeColor(’red’, 2000); await changeColor(’yellow’, 1000); await changeColor(’green’, 3000); }}main();5. 1s后輸出1 2s后輸出2 3s后輸出3

const log = console.log;const sleep = (timeout) => { return new Promise((resolve)=>{ setTimeout(()=>{ resolve(); }, timeout) })}const main = async()=>{ await sleep(1000); log(1); await sleep(2000); log(2); await sleep(3000); log(3);}參考文章:

紅綠燈紅綠燈

到此這篇關于JavaScript sleep睡眠函數的使用的文章就介紹到這了,更多相關JavaScript sleep睡眠函數內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 91视频久久 | 久久一二 | 欧美日韩久久 | 在线视频一区二区 | 一区二区免费 | 成人精品在线观看 | 一级毛片在线播放 | 日韩在线一区二区三区 | 国产成人精品午夜视频免费 | 99视频免费 | 国产中文一区二区三区 | 午夜免费视频 | 一区二区三区国产好 | 国产精品日韩欧美一区二区三区 | 婷婷91| 亚洲精品久久久久久久久久吃药 | 亚洲中国字幕 | 久久免费视频在线 | 欧美日韩福利 | 久草.com | 欧美日韩亚洲国产 | av黄色免费 | 国产一二三视频在线观看 | 蜜臀av日日欢夜夜爽一区 | 伊人狠狠干 | 一级全黄少妇性色生活免费看 | 一级a爱片性色毛片免费 | 99精品99 | 免费看啪啪网站 | 亚洲第一网站 | 国产日韩欧美一区二区 | av日韩在线播放 | h视频在线免费 | 欧美日韩电影一区二区 | 久久久久久久久久毛片 | 国产欧美精品一区二区 | 91久久久久久 | 不卡一区二区三区四区 | 国产精品久久久久久久久免费高清 | 亚洲精品一区二区三区蜜桃久 | 特一级毛片 |