首页 > 其他分享 >Suspense and Fiber- The Intricate Machinery Behind React&#s Rendering Elegance

Suspense and Fiber- The Intricate Machinery Behind React&#s Rendering Elegance

时间:2024-09-21 16:02:53浏览次数:1  
标签:function react Fiber return Elegance next React fiber workloop

react fiber 是 react 并发渲染的核心,它使框架能够将任务分解为更小的单元,并优先处理更重要的任务,从而实现更流畅、响应更灵敏的用户界面。当与 suspense 配合使用时,它允许 react “暂停”渲染,在等待数据获取或计算等任务完成时显示后备 ui。fiber 是一个 javascript 对象,代表 react 中的一个工作单元。它在渲染过程中保存有关组件的重要信息:那篇文章中的所有代码都是伪代码。真实文件链接可以在文末找到{ tag, // the type of fiber (e.g., hostcomponent, functioncomponent) statenode, // the actual dom node or instance for class components memoizedprops, // props used during the last render memoizedstate, // state used during the last render return, // parent fiber sibling, // next sibling fiber child, // first child fiber alternate, // link to the previous fiber (for reconciling updates)}登录后复制纤程树 允许 react 高效地遍历组件树,执行渲染工作,并跟踪更新、状态和 dom 突变。让我们构建一个由页眉、内容和页脚组件组成的简单应用程序。为了强调 fiber 的工作原理,我们将让 header 执行繁重的计算。function app() { return ( <suspense fallback="{&lt;div">loading...}&gt; <header></header><content></content><footer></footer></suspense> );}function header() { // simulating heavy computation for (let i = 0; i header with heavy computation;}function content() { return <p>this is the content area</p>;}function footer() { return <footer>footer content</footer>;}登录后复制它是如何开始的? render 函数负责启动 react 中的初始渲染过程。它需要一个根组件(如 app)并为 react 创建初始的 fiber 树:function render(element, container) { const rootfiber = { tag: hostroot, // root fiber tag statenode: container, // reference to the dom container child: null, // initial child will be added here }; // create a new work-in-progress fiber for our app component const appfiber = createfiberfromelement(element); rootfiber.child = appfiber; // start the rendering process schedulework(rootfiber);}登录后复制然后工作安排就开始行动了。 schedulework 负责启动工作循环并处理 fiber 树。它决定何时开始处理工作,通常使用workloop。function schedulework(rootfiber) { nextunitofwork = rootfiber; // set the root fiber as the starting point requestidlecallback(workloop); // begin processing fibers when the browser is idle}登录后复制这里,根 fiber 被设置为 nextunitofwork,react 调度 workloop 函数来处理它。 react 使用 requestidlecallback 等待浏览器空闲后再开始工作,这对于非阻塞渲染至关重要。如前所述,workloop 和performunitofwork 处理纤程的实际处理。这是协调阶段。workloop 通过调用 performunitofwork 来处理每个 fiber,直到所有任务完成或浏览器需要优先处理其他任务。function workloop() { while (nextunitofwork &amp;&amp; !shouldyield()) { nextunitofwork = performunitofwork(nextunitofwork); // perform work for the next fiber } if (!nextunitofwork) { // commit all completed work to the dom commitroot(); } else { // yield control and schedule the next chunk of work requestidlecallback(workloop); }}登录后复制performunitofwork 处理各个纤维,检查 suspense 边界,启动渲染任务并管理更新。function performunitofwork(fiber) { const next = beginwork(fiber); // if there's more work to do, return the next unit if (next) { return next; } // otherwise, complete the work and move to the next sibling or parent let sibling = fiber.sibling; if (sibling) { return sibling; } return fiber.return;}function beginwork(fiber) { if (fiber.tag === suspensecomponent) { if (fiber.suspensestate === suspended) { // render fallback ui if data is not ready return fiber.fallback; } else if (fiber.suspensestate === resolved) { // render actual content once data resolves return fiber.child; } } // continue rendering for other fibers}登录后复制完成所有工作单元后,commitroot 负责将 fiber 树提交到 dom,包括处理 suspense fallback ui。这是提交阶段。function commitRoot() { let fiber = rootFiber; while (fiber) { if (fiber.tag === SuspenseComponent &amp;&amp; fiber.suspenseState === Suspended) { // Commit fallback UI if Suspense is active updateDOM(fiber.stateNode); } else { // Commit normal content updateDOM(fiber.memoizedProps); } // If the fiber has a passive effect (i.e., useEffect), schedule it if (fiber.effectTag === Passive) { // Function to schedule the useEffect hooks to run after the DOM updates and browser paint scheduleEffectHooks(fiber); } fiber = fiber.next; // Move to the next fiber in the tree }}登录后复制在提交阶段,react 会为任何具有副作用(例如 useeffect)的 fiber 调用 scheduleeffecthooks。这些钩子被推迟到 dom 更新和浏览器绘制之后,以避免阻塞渲染过程。这使得 react 能够执行非阻塞更新,同时确保 ui 稳定后及时执行副作用。在本文中,我们探讨了 react fiber 架构的内部工作原理以及 suspense 如何与其交互以增强渲染过程。我们了解了 react 如何将渲染任务分解为更小的单元,确定重要任务的优先级,并推迟不太重要的更新,以保持用户界面流畅且响应迅速。我们对 fiber 树结构、工作调度过程以及协调和提交阶段如何有效更新 dom 有了清晰的了解。我们还探讨了 suspense 如何集成到该架构中,在等待数据或繁重计算时显示后备内容。如果您对本文有任何反馈或想法 - 无论部分不清楚还是可以改进 - 我很高兴听到它们。您的见解将有助于为每个人完善和增强内容。来源和原始实现:反应纤维概述:反应悬念:performunitofwork 的当前实现:beginwork 的当前实现:commitroot 的当前实现:schedulework 和 workloop 的当前实现以上就是Suspense and Fiber: The Intricate Machinery Behind React&#s Rendering Elegance的详细内容,更多请关注我的其它相关文章!

标签:function,react,Fiber,return,Elegance,next,React,fiber,workloop
From: https://www.cnblogs.com/aow054/p/18424123

相关文章

  • Redux 与 ContextProvider:在 React 应用程序中选择状态管理
    长话短说当您需要一个强大且可扩展的解决方案来进行复杂的状态管理时,请使用redux,特别是在具有许多组件与状态交互的大型应用程序中。当你的状态管理需求更简单、更本地化,或者当你想避免小型应用程序中redux的开销时,请使用context.provider。让我们开始吧在react或nex......
  • React 设计模式~布局组件~
    屏幕分割器这种模式经常用于由侧边栏、主栏等组成的常见布局。?app.jsimport{splitscreen}from"./components/split-screen";constleftside=({title})=>{return<h2style="{{"backgroundcolor:>{title}</h2>;};constrightside=({title})=>{......
  • ReactJS 设计模式:编写健壮且可扩展的组件
    reactjs中的设计模式为应用程序开发中的常见问题提供了标准化且经过验证的解决方案。使用这些模式不仅使您的代码更具可读性和可维护性,而且还增强了其可扩展性和健壮性。让我们深入研究一些最流行的reactjs设计模式,并通过示例来说明它们的用法。1.容器和表示组件模式容......
  • Recharts:终极 React 图表库
    在当今数据驱动的世界中,有效可视化数据的能力比以往任何时候都更加重要。无论您是数据科学家、开发人员还是业务分析师,创建富有洞察力的交互式图表都可以帮助您清晰地传达复杂的信息。用于此目的的最佳工具之一是recharts——一个完全基于react组件构建的可组合图表库。在这篇......
  • React Native 最佳实践
    如果您是reactnative开发者初学者,或者有经验,那么您必须意识到代码实践是一项不容妥协的技能。作为开发人员,项目的交付是必须的,但编写可扩展且高质量的代码将对您和您的团队的未来有所帮助。在我们继续之前,这些实践可以在reactnativecli或expo项目上使用。从2024年开始,r......
  • React 与 React (RC):主要区别和迁移技巧与示例
    react是用于构建用户界面的流行javascript库,随着每个新版本的发布而不断发展。在这篇博文中,我们将探讨react18和即将推出的react19(目前处于候选发布阶段)之间的主要区别,提供新功能示例,并为使用react和vite的开发人员提供迁移技巧。目录简介react19的当前状态与......
  • React 中的上下文:更好的方法
    首先看一下这段代码:usercontext.jsimport{createcontext,usecontext}from"react";constusercontext=createcontext({user:{name:'defaultuser',age:0},setuser:()=>{}//wecanalsopassstatehere.});exportconstthemeprovider=......
  • React 心态:新 React 开发人员应该如何思考
    react是一个用于构建用户界面的流行javascript库,它使开发人员能够创建可重用的组件并有效管理复杂的ui,从而彻底改变了前端开发。然而,采用正确的心态对于新开发人员驾驭react独特范例至关重要。让我们探索塑造“react心态”的基本原则和策略。1.组件化思考react的核......
  • 前端框架Vue、React、Angular、Svelte对比
    编辑在对比React、Vue.js、Angular和Svelte时,除了在高层次的特性上有显著差异,它们在核心设计理念和底层实现机制上也有明显的不同。为了清晰地理解这些框架,我们可以从以下几个方面来分析它们的核心不同点和底层不同点。1.框架类型和设计哲学React:类型:UI库(视图层)设计哲学:React......
  • ReactJS + Stripe:试用期天数未按预期工作
    :试用期天数未按预期工作一、问题描述(一)预期的试用期天数该应用程序使用ReactJS和Stripe进行支付处理。试用期天数应设置为14天,但实际试用期天数并未按预期工作。用户在注册后,试用期仅持续了7天,而不是预期的14天。这导致用户在试用期结束前就被要求支付订阅费用,给用户带来......