题目描述
要求实现一个Quene类,包括
task
方法
- 传入两个参数
- 延迟执行时间(单位:ms)
- 执行的函数
- 要求实现链式调用
start
方法
- 执行
start
方法后依次执行(执行完上一个task方法中的函数后才能执行下一个)
示例
执行结果:一秒后输出a,十秒后输出b ,再过两秒输出c
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)
}
}
如果有更好的方法 欢迎评论区交流!!