首页 > 社交 > 科普中国

Vue

常驻编辑 科普中国 2022-10-17 华为   队列   函数   原始   定义   作用   事件   操作   发现   数据
CNq拜客生活常识网

通过上面任意一种方法,进行降级操作CNq拜客生活常识网

export let isUsingMicroTask = false
if (typeof Promise !== 'undefined' && isNative(Promise)) {
  //判断1:是否原生支持Promise
  const p = Promise.resolve()
  timerFunc = () => {
    p.then(flushCallbacks)
    if (isIOS) setTimeout(noop)
  }
  isUsingMicroTask = true
} else if (!isIE && typeof MutationObserver !== 'undefined' && (
  isNative(MutationObserver) ||
  MutationObserver.toString() === '[object MutationObserverConstructor]'
)) {
  //判断2:是否原生支持MutationObserver
  let counter = 1
  const observer = new MutationObserver(flushCallbacks)
  const textNode = document.createTextNode(String(counter))
  observer.observe(textNode, {
    characterData: true
  })
  timerFunc = () => {
    counter = (counter + 1) % 2
    textNode.data = String(counter)
  }
  isUsingMicroTask = true
} else if (typeof setImmediate !== 'undefined' && isNative(setImmediate)) {
  //判断3:是否原生支持setImmediate
  timerFunc = () => {
    setImmediate(flushCallbacks)
  }
} else {
  //判断4:上面都不行,直接用setTimeout
  timerFunc = () => {
    setTimeout(flushCallbacks, 0)
  }
}

无论是微任务还是宏任务,都会放到flushCallbacks使用CNq拜客生活常识网

这里将callbacks里面的函数复制一份,同时callbacks置空CNq拜客生活常识网

依次执行callbacks里面的函数CNq拜客生活常识网

function flushCallbacks () {
  pending = false
  const copies = callbacks.slice(0)
  callbacks.length = 0
  for (let i = 0; i < copies.length; i++) {
    copies[i]()
  }
}

四、最后总结

  1. 把回调函数放入callbacks等待执行
  2. 将执行函数放到微任务或者宏任务中
  3. 事件循环到了微任务或者宏任务,执行函数依次执行callbacks中的回调

相关阅读:

  • 华为天际通流量卡能插手机吗
  • nova9没有5g版
  • 华为nova9支持鸿蒙吗
  • mix4和mate40选哪个
  • 华为nova10会出吗2021
  • 华为手机字体怎么改(华为手机怎么调整字体样式)
  • 华为怎么开热点(华为手机怎么开热点给别人连)
  • 手机桌面停止运行怎么办(华为桌面崩溃)
  • 华为笔记本电脑怎么样(四五千买华为还是华硕笔记本)
  • 手机进水怎么处理(华为一体机手机进水怎么办)
    • 网站地图 |
    • 声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。文章内容仅供参考,不做权威认证,如若验证其真实性,请咨询相关权威专业人士。