亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript如何實現紅綠燈

發布時間:2021-11-16 14:36:38 來源:億速云 閱讀:304 作者:iii 欄目:web開發

本篇內容介紹了“javascript如何實現紅綠燈”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

javascript實現紅綠燈的方法:1、使用setTimeout和遞歸來實現循環改變顏色;2、使用Promise,并把下一次的顏色改變寫在then里面;3、使用async await和while實現紅綠燈效果。

javascript如何實現紅綠燈

本教程操作環境:windows7系統、javascript1.8.5版本、Dell G3電腦。

javascript怎么實現紅綠燈?

JavaScript 實現紅綠燈

??使用setTimeout、Promise、async await 三種方式實現紅綠燈代碼,紅燈2秒,黃燈1秒,綠燈3秒,循環改變顏色。改變顏色的方法,就簡單寫成打印出顏色。

setTimeout實現

??使用setTimeout是最基本的實現方式,代碼如下,使用遞歸來實現循環改變顏色。

function changeColor(color) {
console.log('traffic-light ', color);
}
function main() {
changeColor('red');
setTimeout(()=>{
changeColor('yellow');
setTimeout(() => {
changeColor('green');
setTimeout(main, 2000);
}, 1000);
}, 2000);
}
main();

Promise 實現

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

function sleep(duration){
    return new Promise(resolve => {
        setTimeout(resolve, duration);
    })
}
function changeColor(duration,color){
    return new Promise(resolve => {
console.log('traffic-light ', color);
    sleep(duration).then(resolve);
})
}
function main() {
return new Promise(resolve => {
changeColor(2000, 'red').then(() => {
changeColor(1000, 'yellow').then(() => {
changeColor(3000, 'green').then(() => {
main();
})
})
})
})
}main();

async await 實現

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

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

“javascript如何實現紅綠燈”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彩票| 彭山县| 澳门| 崇信县| 外汇| 新闻| 青神县| 通州市| 治多县| 化州市| 宝山区| 夏河县| 车险| 日照市| 汽车| 北安市| 天等县| 灵台县| 贡嘎县| 启东市| 青田县| 延津县| 化州市| 黄石市| 勐海县| 甘孜县| 绿春县| 信阳市| 衡阳县| 金山区| 武安市| 宁晋县| 靖边县| 台山市| 沁阳市| 昆山市| 南华县| 双城市| 渭源县| 浮梁县| 镇安县|