首页前端开发JavaScriptjavascript怎么实现红绿灯

javascript怎么实现红绿灯

时间2024-01-30 18:56:03发布访客分类JavaScript浏览648
导读:收集整理的这篇文章主要介绍了javascript怎么实现红绿灯,觉得挺不错的,现在分享给大家,也给大家做个参考。javascript实现红绿灯的方法:1、使用setTimeout和递归来实现循环改变颜色;2、使用Promise,并把下一次的...
收集整理的这篇文章主要介绍了javascript怎么实现红绿灯,觉得挺不错的,现在分享给大家,也给大家做个参考。

javascript实现红绿灯的方法:1、使用setTimeout和递归来实现循环改变颜色;2、使用Promise,并把下一次的颜色改变写在then里面;3、使用async await和while实现红绿灯效果。

本教程操作环境: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基础教程》

以上就是javascript怎么实现红绿灯的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: jquery attr()怎么显示隐藏元素下一篇:jquery怎么去掉td里的内容猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: javascript怎么实现红绿灯
本文地址: https://pptw.com/jishu/592908.html
C#之FastSocket实战项目的示例分享 jquery怎样隐藏table的tr

游客 回复需填写必要信息