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

响应式网站制作视频天津网站建设流程

响应式网站制作视频,天津网站建设流程,为网站制定推广计划,深圳英文网站建设公司HostRoot 的更新 1 #xff09;概述 HostRoot 是一个比较特殊的节点, 因为在一个react应用当中它只会有一个 HostRoot, 它对应的 Fiber 对象是我们的 RootFiber 对象重点在于它的更新过程 2 #xff09;源码 定位到 packages/react-reconciler/src/ReactFiberBeginWork.js…HostRoot 的更新 1 概述 HostRoot 是一个比较特殊的节点, 因为在一个react应用当中它只会有一个 HostRoot, 它对应的 Fiber 对象是我们的 RootFiber 对象重点在于它的更新过程 2 源码 定位到 packages/react-reconciler/src/ReactFiberBeginWork.js#L612 // 这个函数的重点在: update 来自哪里, 里面是什么内容 // 最终通过 processUpdateQueue 得到了 element 里面的内容之后以此作为children来调和 function updateHostRoot(current, workInProgress, renderExpirationTime) {// 跳过 context 相关pushHostRootContext(workInProgress);const updateQueue workInProgress.updateQueue;invariant(updateQueue ! null,If the root does not have an updateQueue, we should have already bailed out. This error is likely caused by a bug in React. Please file an issue.,);// 获取一系列数据const nextProps workInProgress.pendingProps;const prevState workInProgress.memoizedState;// 对于 HostRoot 一开始是没有 state也就是 prevState.element, 在第一次渲染的时候prevState 是 null在ReactDOM.render中创建了一个update// 经过 processUpdateQueue 这次更新后它会拿到一个 {element} 对象作为 stateconst prevChildren prevState ! null ? prevState.element : null;// 得到创建的update传递的elementprocessUpdateQueue(workInProgress,updateQueue,nextProps,null,renderExpirationTime,);const nextState workInProgress.memoizedState;// Caution: React DevTools currently depends on this property// being called element.const nextChildren nextState.element;if (nextChildren prevChildren) {// If the state is the same as before, thats a bailout because we had// no work that expires at this time.resetHydrationState(); // 服务端渲染复用dom节点相关内容// 跳出更新过程不需要更新// 对 RootFiber来说大部分情况下只在 ReactDOM.render 的时候有更新其他时候都不需要更新// 一般都是在App内更新不会在RootFiber节点创建更新return bailoutOnAlreadyFinishedWork(current,workInProgress,renderExpirationTime,);}const root: FiberRoot workInProgress.stateNode;// 跳过 hydrate 相关if ((current null || current.child null) root.hydrate enterHydrationState(workInProgress)) {// If we dont have any current children this might be the first pass.// We always try to hydrate. If this isnt a hydration pass there wont// be any children to hydrate which is effectively the same thing as// not hydrating.// This is a bit of a hack. We track the host root as a placement to// know that were currently in a mounting state. That way isMounted// works as expected. We must reset this before committing.// TODO: Delete this when we delete isMounted and findDOMNode.workInProgress.effectTag | Placement;// Ensure that children mount into this root without tracking// side-effects. This ensures that we dont store Placement effects on// nodes that will be hydrated.// 在 current null || current.child null 这种情况下都是第一次渲染workInProgress.child mountChildFibers(workInProgress,null,nextChildren,renderExpirationTime,);} else {// Otherwise reset hydration state in case we aborted and resumed another// root.// 不是第一次渲染reconcileChildren(current,workInProgress,nextChildren,renderExpirationTime,);resetHydrationState();}return workInProgress.child; }HostRoot 创建更新的过程就是在 ReactFiberReconciler.js 中的调用 ReactDOM.render 的过程定位到 scheduleRootUpdate 位置在 packages/react-reconciler/src/ReactFiberReconciler.js#L110function scheduleRootUpdate(current: Fiber,element: ReactNodeList,expirationTime: ExpirationTime,callback: ?Function, ) {// ... 省略const update createUpdate(expirationTime);update.payload {element};// ... 省略return expirationTime; }它这里创建一个 update, 并挂在 update.payload 是 {element}这个 element 就是传给 ReactDOM.render 的第一个参数这个 update 对象没有后续指定类型这和调用 setState 在组件内创建更新效果是类似的所以update.payload 就相当于 state对于 HostRoot 来说, 它的state只有一个属性就是element就是 ReactDOM.render 的第一个参数
http://www.w-s-a.com/news/104319/

相关文章:

  • 网站建设期末试卷大气简洁网站
  • 电子商务网站建设报告范文单位做网站怎么做
  • 优质的外国网站qq小程序在哪里打开
  • 商务网站建设与推广实训报告免费素材网站无水印
  • 外贸站seoapp开发公司历程概述
  • 沈阳网站推广¥做下拉去118cr陶瓷企业 瓷砖地板公司网站建设
  • 医院网站官方微信精神文明建设我做服装设计师的 求推荐资源网站
  • 微信网站建设需要那些资料昆明cms模板建站
  • 安庆网站建设兼职中企动力是500强吗
  • 网站排名优化技巧基于网站的网络营销方法有哪些
  • 摄影素材网站做知识问答的网站
  • 中小企业网站建设济南兴田德润电话门店管理系统软件排行
  • 昆明工程建设信息网站柳州网站建设公司哪家好
  • 如何分析网站关键词北京门户网站网址
  • 做网站与做游戏那个好网站域名怎么起
  • 有没有做cad单的网站银行网站建设方案视频
  • 和各大网站做视频的工作高校网站群管理系统
  • 中国建设人才服务信息网是正规网站怎么注销自己名下的公司
  • 网站开发新型技术那些网站做任务领q币
  • 海口手机网站建设wordpress微支付宝
  • 做公司网站需要几天深圳自定义网站开发
  • 做网站学多长时间可以学会推广软件公司
  • 网络网站设计培训长沙建站模板大全
  • 站群搭建移动端处理器天梯图
  • 岳池发展建设集团有限公司门户网站湛江seo咨询
  • 手机网站工具关键词排名是什么意思
  • 游民星空是谁做的网站沈阳网站托管公司
  • 做网站搭建需要什么人vs2017移动网站开发
  • 购物网站开发需要什么技术怎么查看网站是否备案
  • 学做电商那个网站好网站建设投票主题