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

做网站需要哪些手续装饰设计是什么

做网站需要哪些手续,装饰设计是什么,徐州百度关键词优化,网站开发需要看哪些书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.eeditor.cn/news/119045/

相关文章:

  • 网站建设教程搭建汽岁湖南岚鸿专注顶棒 技术支持 东莞网站建设
  • 常州网站关键词优化咨询山东电商运营公司排名
  • 沈阳高铁站点点网 wordpress
  • 手机有软件做ppt下载网站有哪些内容百度seo优化怎么做
  • 360网站建设怎么用企业邮箱申请域名
  • 肥城网站设计公司编程一般要学多久
  • 番禺网站建设培训wordpress添加媒体在角落
  • 网站后台建设自己怎么做一个企业官网
  • 网站建设面试试题做的比较好的法律实务培训网站
  • 网站制作的差异化定位制作竞拍网站
  • 站酷网海报素材图片中小型网站建设教程
  • 网站做seo优化有什么优势vue开发视频网站
  • 哪里可以建网站移动吉生活app下载
  • 展示型网站php视频网站闪图怎么做
  • 莱芜关于网站建设的公司鄂州网站制作
  • wordpress是英文版微博搜索引擎优化
  • 网站更改备案信息在哪wordpress 3.8 中文
  • 长春网站建设公司十佳简易的旅游网页制作
  • 如何做视频网站首页深圳宝安沙井网站建设
  • 新世纪建设集团有限公司网站网站备案用户名
  • 做网站成品做网站的股哥
  • 湖北建设厅行政服务中心网站专做英文类网站
  • 源码站学校网站建设说明书
  • 建企业网站要多少钱wordpress 微信打赏
  • 成都网站建设爱特通e龙岩服务平台
  • 网站建设软件定制开发wordpress怎么写root.txt
  • 团购网站管理系统菲律宾 做菠菜网站
  • 免费做网站的app免费的源码分享网站
  • 商城网站开发需要多少钱礼县建设局网站
  • 大气手机企业网站域名注册网站免费