如何实现【红绿灯】的问题

背景

最近遇到个面试题:点亮绿灯3s,然后点亮黄灯1s,然后点亮红灯2s,然后重复循环。估计是考察ES6 Promise相关内容。那如何更好的实现呢?

Promise实现

function red () {
    console.log('red')
}

function green () {
    console.log('green')
}

function yellow() {
    console.log('yellow')
}

function genPromise(func, timeout) {
    return () => {
        func();
        return new Promise((resolve) => setTimeout(resolve, timeout))
    }
}

var redPromise = genPromise(red, 2000), 
    greenPromise = genPromise(green, 3000),
    yellowPromise = genPromise(yellow, 1000);

function step() {
    greenPromise().then(() => yellowPromise()).then(() => redPromise()).then(() => step())
}

// 启动
step();

改进

step函数的貌似写复杂了,yellowPromise函数本身返回的就是个Promise对象,那给then方法传递的箭头函数冗余了。修改step函数:

function step() {
    greenPromise().then(yellowPromise).then(redPromise).then(step)
}
//启动
step();

再改进

使用async/wait改进下step函数:

async function step() {
    await greenPromise();
    await yellowPromise();
    await redPromise();
    step();
}
// 启动
step();

不止这些...

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值