按照调用实例,实现下面的Person方法

要求如下:

Person("Li");
// 输出: Hi! This is Li!

Person("Dan").sleep(10).eat("dinner");
// 输出:
// Hi! This is Dan!
// 等待10秒..
// Wake up after 10
// Eat dinner~

Person("Jerry").eat("dinner").eat("supper");
// 输出:
// Hi This is Jerry!
// Eat dinner~
// Eat supper~

Person("Smith").sleepFirst(5).eat("supper");
// 输出:
// 等待5秒
// Wake up after 5
// Hi This is Smith!
// Eat supper

代码如下:

function Person2(name){
    this.isRunFlag = false;
    this.name = name;
    this.taskArr = [];
    function task (name) {
        console.log(`Hi! This is ${name}!`);
    }
    this.taskArr.push(task.bind(this, name));
    this.run();
}
Person2.prototype.eat = function (food) {
    const task = food => {
        console.log(`Eat ${food}~`);
    }
    this.taskArr.push(task.bind(this, food));
    this.run();
    return this;
}
Person2.prototype.sleep = function (time) {
    const task = new Promise((resolve, reject) => {
        setTimeout(() => {
            console.log(`Wake up after ${time}`);
            resolve();
        }, time * 1000);
    })
    this.taskArr.push(task);
    this.run();
    return this;
}
Person2.prototype.sleepFirst = function (time) {
    const task = new Promise((resolve, reject) => {
        setTimeout(() => {
            console.log(`Wake up after ${time}`);
            resolve();
        }, time * 1000);
    })
    this.taskArr.unshift(task);
    this.run();
    return this;
}
Person2.prototype.run = function () {
    if (this.isRunFlag) {
        return;
    }else{
        this.isRunFlag = true;
        const gogogo = () => {
            if (this.taskArr.length) {
                let task = this.taskArr.shift();
                if (task.then) {
                    task.then(() => {
                        gogogo();
                    })
                } else {
                    task();
                    gogogo();
                }
            } else {
                this.isRunFlag = false;
            }
        }
        Promise.resolve().then((res) => {
            gogogo();
        }).catch((error) => {
            console.log("error:", error);
        })
    }
}
function Person(name){
    return new Person2(name);
}

关注微信公众号,解锁更多技术文章
关注微信公众号,解锁更多技术文章

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值