JavaScript 手写setTimeout

Posted 荣光无限

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 手写setTimeout相关的知识,希望对你有一定的参考价值。

let setTimeout = (sec, num) => {
  // 初始当前时间
  const now = new Date().getTime()
  let flag = true
  let count = 0
  while (flag) {
    count++
    // 再次运行时获取当前时间
    const after = new Date().getTime()
    // 需要等待的时间
    const dealy = sec * 1000
    // 当前运行时间 - 初始当前时间 >= 等待时间 ===>> 跳出
    if (after - now >= dealy) {
      flag = false
    } else {
      console.info(‘count‘, count)
    }
  }
  return new Promise((resolve, reject) => {
    resolve(num * num)
  })
}

let result = ‘‘
const res = setTimeout(3, 10)
console.info(res) // Promise { 100 }
// 返回的是一个promise,promise中resolve中的值需要在then中拿到
res.then(x => {
  result = x
  console.info(result) // 100
})

以上是关于JavaScript 手写setTimeout的主要内容,如果未能解决你的问题,请参考以下文章

22 道高频 JavaScript 手写面试题及答案

手写promise异步状态修改then方法返回来的结果

setTimeout 函数执行代码没有任何延迟。 Javascript [重复]

javascript的setTimeout()与setTimeout()方法用法总结

Javascript - 在递归函数中获取 setTimeout 的返回值

JavaScript———原理题