美文网首页
实现一个LazyMan

实现一个LazyMan

作者: 指尖跳动 | 来源:发表于2020-02-18 10:01 被阅读0次

实现一个LazyMan,可以按照以下方式调用:

LazyMan(“Hank”)输出:
Hi! This is Hank!

LazyMan(“Hank”).sleep(10).eat(“dinner”)输出
Hi! This is Hank!
//等待10秒..
Wake up after 10
Eat dinner~

LazyMan(“Hank”).eat(“dinner”).eat(“supper”)输出
Hi This is Hank!
Eat dinner~
Eat supper~

LazyMan(“Hank”).sleepFirst(5).eat(“supper”)输出
//等待5秒
Wake up after 5
Hi This is Hank!
Eat supper
class Man {
  constructor(name) {
    this.actions = [];
    const hello = () => {
      console.log(`Hi This is ${name}!`);
      this.next();
    };

    this.addAction(hello);
    setTimeout(() => {
      this.next();
    }, 0);
  }

  next() {
    if (this.actions.length > 0) {
      const fn = this.actions.shift();
      if ((typeof fn).toLowerCase() === 'function') {
        fn();
      }
    }
  }

  addAction(func, isFirst) {
    if (!isFirst) {
      this.actions.push(func);
    } else {
      this.actions.unshift(func);
    }
  }

  eat(food) {
    const eatFunc = () => {
      console.log(`Eat ${food}~`);
      this.next();
    };
    this.addAction(eatFunc);
    return this;
  }

  sleep(time) {
    const sleepFn = () => {
      setTimeout(() => {
        console.log(`Wake up after ${time}ms`);
        this.next();
      }, time);
    };
    this.addAction(sleepFn);
    return this;
  }

  sleepFirst(time) {
    const sleepFirst = () => {
      setTimeout(() => {
        console.log(`Wake up after ${time}ms`);
        this.next();
      }, time);
    };

    this.addAction(sleepFirst, true);
    return this;
  }
}

function LazyMan(name) {
  return new Man(name);
}

参考:
https://www.cnblogs.com/XHappyness/p/12212790.html
https://www.cnblogs.com/EnSnail/p/9866130.html

相关文章

  • js重点与难点(转)

    javascript LazyMan实现LazyMan(什么是LazyMan?请自行google)function...

  • LazyMan的实现

    题目介绍 实现一个 LazyMan,可以按照以下方式调用:LazyMan("Hank") 输出:Hi! This ...

  • lazyman

    实现一个LazyMan,可以按照以下方式调用:LazyMan(“Hank”)输出:Hi! This is Hank...

  • LazyMan 实现...

    // 实现一个LazyMan,可以按照以下方式调用:// LazyMan(“Hank”)输出:// Hi! Thi...

  • 实现一个LazyMan

    实现一个 LazyMan,可以按照以下方式调用:LazyMan("Hank")输出:Hi! This is Han...

  • LazyMan的深入解析和实现

    一、题目介绍 以下是我copy自网上的面试题原文: 实现一个LazyMan,可以按照以下方式调用:LazyMan(...

  • Lazyman的两种实现方式

    实现一个LazyMan, 可以按下列方式调用: 方式一: 方式二:

  • lazyman 实现

    function _lazyman(name) {this.tasks = [];var self = this;...

  • 实现lazyMan

    涉及的知识点: 流程控制:创建task任务队列,使用push、shift、unshift方法操作任务 闭包:当闭包...

  • LazyMan 自己的笨办法

    LazyMan 自己的笨办法 看了LazyMan,先用自己的笨办法写了个,只是为了实现功能,其他要求都没达到 本人...

网友评论

      本文标题:实现一个LazyMan

      本文链接:https://www.haomeiwen.com/subject/snnwfhtx.html