手写一个LazyMan,实现sleep机制

实现 `sleep` 和 `eat` 两个方法

支持链式调用

const me = new LazyMan('li')
me.eat('苹果').eat('香蕉').sleep(5).eat('葡萄') // 打印结果如下:

// 'li eat 苹果'
// 'li eat 香蕉'
// (等待 5s)
// 'li eat 葡萄'

代码设计

由于有 sleep 功能,函数不能直接在调用时触发

初始化一个列表,把函数注册进去

由每个 item 触发 next 执行(遇到 sleep 则异步触发)

 代码

/**
 * @description lazy man
 */

class LazyMan {
    private name: string
    private tasks: Function[] = [] // 任务列表

    constructor(name: string) {
        this.name = name

        setTimeout(() => {
            this.next()
        })
    }

    private next() {
        const task = this.tasks.shift() // 取出当前 tasks 的第一个任务
        if (task) task()
    }

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值