天天看点

记一次字节跳动面试的编程题

题目描述

要求实现一个Quene类,包括
  • task

    方法
    • 传入两个参数
      1. 延迟执行时间(单位:ms)
      2. 执行的函数
    • 要求实现链式调用
  • start

    方法
    • 执行

      start

      方法后依次执行(执行完上一个task方法中的函数后才能执行下一个)

示例

执行结果:一秒后输出a,十秒后输出b ,再过两秒输出c

codepen演示

new Quene()
.task(1000, () => {
 console.log('a')
})
.task(10000, () => {
 console.log('b')
})
.task(2000, () => {
 console.log('c')
}).start()
           

思路

执行task函数的时候,用一个数组去存储之后要执行的函数,在start方法被调用的时候,遍历数组,调用方法

代码实现

function Quene(){
  	this.quene = [] // 用于存储需要执行的方法 
}

Quene.prototype.task = function(interval, fn) {
  this.quene.push(
    // 传入delay函数的作用是为了等上一个函数执行完再执行下一个
    function(delay) { 
      setTimeout(fn, interval+delay)
      return interval+delay //返回前面函数执行一共需要延迟的时间
    }
  )
  return this// 实现链式调用
}

Quene.prototype.start = function() {
  let delay = 0
  for(let i=0;i<this.quene.length;i++){
    delay = this.quene[i](delay)
  }
}
           

如果有更好的方法 欢迎评论区交流!!

继续阅读