中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

德阳市| 佛坪县| 温泉县| 天门市| 井陉县| 紫金县| 绥化市| 陈巴尔虎旗| 嘉峪关市| 郴州市| 哈尔滨市| 望都县| 北海市| 泰安市| 灵武市| 潮州市| 扬州市| 始兴县| 弥渡县| 大连市| 奉化市| 鄱阳县| 潍坊市| 高青县| 周口市| 东乡县| 金溪县| 丹东市| 司法| 博湖县| 木里| 敦煌市| 安化县| 安达市| 岚皋县| 赤水市| 光山县| 深水埗区| 从江县| 浦县| 荃湾区|