当前位置: 首页 > news >正文

网站建设重要意义网上书城网站开发

网站建设重要意义,网上书城网站开发,南昌集团制作网站公司,做网站 360的好不好requestCurrentTime 1 #xff09;概述 关于 currentTime#xff0c;在计算 expirationTime 和其他的一些地方都会用到 从它的名义上来讲#xff0c;应等于performance.now() 或者 Date.now() 就是指定的当前时间在react整体设计当中#xff0c;它是有一些特定的用处和一些…requestCurrentTime 1 概述 关于 currentTime在计算 expirationTime 和其他的一些地方都会用到 从它的名义上来讲应等于performance.now() 或者 Date.now() 就是指定的当前时间在react整体设计当中它是有一些特定的用处和一些特殊的设定的比如说在一次渲染中产生的更新需要使用相同的时间在一次批处理的更新中应该得到相同的时间还有就是挂起的任务用于记录的时候应该也是相同的 2 源码 function requestCurrentTime() {// requestCurrentTime is called by the scheduler to compute an expiration// time.//// Expiration times are computed by adding to the current time (the start// time). However, if two updates are scheduled within the same event, we// should treat their start times as simultaneous, even if the actual clock// time has advanced between the first and second call.// In other words, because expiration times determine how updates are batched,// we want all updates of like priority that occur within the same event to// receive the same expiration time. Otherwise we get tearing.//// We keep track of two separate times: the current renderer time and the// current scheduler time. The renderer time can be updated whenever; it// only exists to minimize the calls performance.now.//// But the scheduler time can only be updated if theres no pending work, or// if we know for certain that were not in the middle of an event.if (isRendering) {// Were already rendering. Return the most recently read time.return currentSchedulerTime;}// Check if theres pending work.findHighestPriorityRoot();if (nextFlushedExpirationTime NoWork ||nextFlushedExpirationTime Never) {// If theres no pending work, or if the pending work is offscreen, we can// read the current time without risk of tearing.recomputeCurrentRendererTime();currentSchedulerTime currentRendererTime;return currentSchedulerTime;}// Theres already pending work. We might be in the middle of a browser// event. If we were to read the current time, it could cause multiple updates// within the same event to receive different expiration times, leading to// tearing. Return the last read time. During the next idle callback, the// time will be updated.return currentSchedulerTime; }第一种情况在 isRendering 的时候会直接返回 currentSchedulerTime, 这个 schedulerTime 而 isRendering 只有在 performWorkOnRoot 的时候才被设置为 true而 performWorkOnRoot 是在 performWork 中被循环调用的performWorkOnRoot 的前后都会重设 currentSchedulerTime这样在 performWorkOnRoot 的时候, isRendering 被设定为 true并且是一个同步的方法使用 performWorkOnRoot 的时候, 后期会调用 render 和 commit 两个阶段在上述两个阶段里都有可能调用组件的生命周期方法在这里有可能产生更新react的设定是在当前渲染流程中如果在生命周期方法里触发了新的更新那么它计算 expirationTime 的时间需要一个固定的时间所以统一返回 currentSchedulerTime这个 currentSchedulerTime 就是在调用 performWorkOnRoot 之前算出来的时间requestCurrentTime 的 if (isRendering) return currentScheudlerTime的设定 第二种情况 调用 findHighestPriorityRoot 找到调度队列中优先级最高的任务如果符合 if (nextFlushedExpirationTime NoWork || nextFlushedExpirationTime Never) 目前没有任务进行或正在更新的组件是从未展现的组件这时候重新计算 renderTime recomputeCurrentRendererTime();并且赋值 currentSchedulerTime currentRendererTime;最终 return currentSchedulerTime 这里和 batchedUpdates 里面类似 创建了 事件的回调多次调用 setState 会创建多个更新计算多次 expirationTime如果没有做这类处理 requestCurrentTime 都去计算一个时间就会导致返回的时间不一致因为时间不一致导致计算出来的 expirationTime不一致那么就导致任务优先级不一致它们会分批次的进行更新就会导致问题在异步的模式下即便只有在最后一次回调调用完之后才会去调用 performWork但是因为任务优先级不同会导致分多次进行调用 所以通过上述判断来规避此类问题第一次调用 setState 之后就在一个root上创建一个更新从 firstScheduledRoot 到 lastScheduledRoot 里面至少会有一个即将要执行的更新在有一个的情况下上述 if 就不满足了就不会直接计算时间直接返回 currentSchedulerTime 这个已保存的时间 expirationTime 1 ) 概述 在计算 expirationTime 之前我们计算的时间是预先处理过的在 requestCurrentTime 函数中有一个 recomputeCurrentRendererTime 2 源码 // /packages/react-reconciler/src/ReactFiberScheduler.js function recomputeCurrentRendererTime() {const currentTimeMs now() - originalStartTimeMs;currentRendererTime msToExpirationTime(currentTimeMs); }// packages/react-reconciler/src/ReactFiberExpirationTime.js // 1 unit of expiration time represents 10ms. export function msToExpirationTime(ms: number): ExpirationTime {// Always add an offset so that we dont clash with the magic number for NoWork.// ms / UNIT_SIZE 为了防止 10ms 之内的误差两个时间差距在10ms以内两个时间看做一致最终计算出来的优先级也是一致return ((ms / UNIT_SIZE) | 0) MAGIC_NUMBER_OFFSET; // UNIT_SIZE 是 10, const MAGIC_NUMBER_OFFSET 是 2 } function computeExpirationBucket(currentTime,expirationInMs,bucketSizeMs, ): ExpirationTime {return (MAGIC_NUMBER_OFFSET ceiling(currentTime - MAGIC_NUMBER_OFFSET expirationInMs / UNIT_SIZE,bucketSizeMs / UNIT_SIZE,)); } export function expirationTimeToMs(expirationTime: ExpirationTime): number {return (expirationTime - MAGIC_NUMBER_OFFSET) * UNIT_SIZE; }在后续 computeExpirationBucket 中 currentTime - MAGIC_NUMBER_OFFSET所以 MAGIC_NUMBER_OFFSET 没有影响到 真正时间的计算误差在10ms以内的前后两个用于计算 expirationTime 的 currentTime它们的误差会被抹平就是 msToExpirationTime 这个方法被设计的意义最终使用具体的时间设置timeout, 判断是否过期的时候会通过 expirationTimeToMs 把这个时间转回来
http://www.dnsts.com.cn/news/130932.html

相关文章:

  • 建立手机也可浏览的网站教程郑州网站建设氵汉狮网络
  • 南昌优化网站推广商业网站域名
  • 长沙网站建站中国最厉害的公关人
  • 四川省建设安全管理协会网站微分销系统是什么
  • 58同城长沙回收网站建设策划书中网站制作怎么写
  • 建设网站怎么判断是电脑还是手机号码建设银行招生网站
  • 定州住房和城乡建设局网站杭州公司的网站建设公司
  • 东莞网络营销网站建设wordpress网站加壳
  • 象客企业网站做优化排名海外永久不收费的加速器
  • 个人网站该怎么打广告建设厅公积金中心网站
  • 做家教的正规网站网站首图怎么做
  • python做电子商务网站什么叫精品网站建设
  • 营商环境网站建设抖音代运营报价表
  • 网站防火墙怎么做上海网站建设 亿速
  • 福州绿光网站建设工作室人力管理系统
  • 手机网站建设制作公司网站seo 规范
  • 广告设计与制作培训机构建筑工程网格优化
  • 网站建设安全外网服务器租用
  • 怎么入侵网站后台管理有做挂名法人和股东的网站吗
  • 网站建设yankt软文300字介绍商品
  • 沈阳做网站哪家好修改文章缩略字数 WORDPRESS
  • 站长工具百科哪家做网站最便宜
  • 石家庄正定新区建设局网站取大气聚财的公司名字
  • 校园网站建设培训班网站平台建设招标书
  • 商丘专业做网站seo人员的相关薪资
  • 淄博做淘宝网站盐山做网站的
  • 可信网站网站认证wordpress 发布到公网
  • 网站建设可行性排名优化的公司
  • 东莞网络营销型网站网站建设需要技术
  • 互联广告精准营销福州网站seo优化公司