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

长沙网站排名推广网站首页适合vue做吗

长沙网站排名推广,网站首页适合vue做吗,丰收路网站建设,韩国在中国做美食的视频网站有哪些前置文章: React原理之 React 整体架构解读React原理之整体渲染流程 -----读懂这一篇需要对 React 整体架构和渲染流程有大致的概念 😊----- 在React原理之 React 整体架构解读中,简单介绍了 Fiber 架构,也了解了 Fiber 节点的…

前置文章:

  1. React原理之 React 整体架构解读
  2. React原理之整体渲染流程

-----读懂这一篇需要对 React 整体架构和渲染流程有大致的概念 😊-----

在React原理之 React 整体架构解读中,简单介绍了 Fiber 架构,也了解了 Fiber 节点的概念。

Fiber 节点是 Fiber 架构的核心概念之一,它是一种虚拟 DOM 的实现方式。

Fiber 本质上是一个对象, 使用了链表结构

双重缓冲是一种渲染优化技术,其使用两个 Fiber 树来管理渲染,即当前树 current tree工作树 work-in-progress tree。当前树代表屏幕上当前显示的内容,而工作树用于准备下一次的渲染更新,用以实现平滑的更新。

Fiber 的含义

前面反复提到,与 React16 之前的栈式架构相比,Fiber 架构中的更新工作是可以中断的循环过程。

fiber 译为“纤维”,React 的 Fiber 架构借鉴了 Fiber 作为轻量级、可调度执行单元的概念,将其应用于组件的渲染和更新过程中。

实际上,Fiber包含三层含义:

  1. fiber 架构
  2. 静态的数据结构
  3. 动态的工作单元

fiber 架构

React16之前的Reconciler采用递归的方式执行,数据保存在递归调用栈中,所以被称为stack ReconcilerReact16Reconciler基于Fiber节点实现,被称为Fiber Reconciler,各个 FiberNode 之间通过链表的形式串联起来。

在这里插入图片描述

看一下简化版源码:

function FiberNode(tag, pendingProps, key, mode) {//...// Fiber树结构:周围的 Fiber Node 通过链表的形式进行关联this.return = null; // 上一级节点this.child = null; // 第一个子节点this.sibling = null; // 下一个同级节点this.index = 0; // 在上一级节点中的索引//...
}

静态的数据结构

作为静态的数据结构来说,每个Fiber节点对应一个React element,保存了该组件的类型(函数组件/类组件/原生组件…)、对应的 DOM 节点等信息。

function FiberNode(tag, pendingProps, key, mode) {//...// 实例属性:// 节点类型标记 Function/Class/Host...this.tag = tag;// key属性this.key = key;// 组件的元素类型,大部分情况同type,某些情况不同,比如FunctionComponent使用React.memo包裹this.elementType = null;// 实际的 JavaScript 对象类型。对于 FunctionComponent,指函数本身,对于ClassComponent,指class,对于HostComponent,指DOM节点tagNamethis.type = null;// 节点对应的真实DOM节点this.stateNode = null;//...
}

动态的工作单元

作为动态的工作单元来说,每个Fiber节点保存了本次更新中该组件改变的状态、要执行的工作(需要被删除/被插入页面中/被更新…)。

// Props和State 改变相关信息
this.pendingProps = pendingProps; // 当前待处理的props
this.memoizedProps = null; // 上次渲染完成,已应用到组件的props
this.updateQueue = null; // 更新队列,用于存储状态更新和回调
this.memoizedState = null; // 上次渲染完成后的state,即组件的当前状态
this.dependencies = null; // 依赖列表,用于追踪副作用this.mode = mode; // Fiber的模式// Effects 副作用
this.flags = NoFlags; // Fiber的标志位,表示Fiber的生命周期状态
this.subtreeFlags = NoFlags; // 子树的标志位
this.deletions = null; // 待删除的子Fiber列表// 优先级调度
this.lanes = NoLanes; // 当前Fiber的优先级
this.childLanes = NoLanes; // 子Fiber的优先级

下一篇:React原理之Fiber双缓冲

http://www.yayakq.cn/news/989102/

相关文章:

  • 房产网站搭建德州网架公司
  • 关键词网站排名查询互联网行业怎么赚钱
  • 集约化网站建设情况经验材料wordpress手机菜单导航
  • 下载百度2023最新版安装深圳网站建设seo推广优化
  • 做网站怎么租个域名flash如何做网页
  • 大同网站建设熊掌号wordpress退出登录界面
  • wordpress本地网站怎么访问淘宝联盟交钱建设网站
  • 济南手机建站哪家好电子商务网站建设 试卷
  • 合肥网站公司哪家好太仓网站建设平台
  • 做旅游网站都需要的调查网络推广哪家好
  • 做网站用什么编程语言好wordpress 交流
  • 汕头企业网站建站模板外贸网站优化推广
  • 网站上线除了备案还需要什么校园网站建设的优点
  • 免费seo网站的工具工程建设标准强制性条文最新版本
  • 找建筑类工作哪个网站好erp项目管理软件
  • 淘客网站如何做推广金银回收东莞网站建设
  • 望牛墩网站仿做wordpress文章列表分页
  • 杭州建设网站需要多少钱洛阳建站优化教程
  • 滨州网站定制百度舆情
  • 阿里云 网站托管网站开发的选题意义及背景
  • 西宁电子商务网站建设网站建设需求方案文档
  • 游戏设计网站wordpress软件
  • 在线咨询 1 网站宣传秦皇岛网站制作公司哪家好
  • 做网站时如何确定网站主题sem百度竞价推广
  • 昆山建站公司网站建设遵循原则
  • 做网站1核1g服务器够吗最近发生的军事重大新闻
  • 哪里可以买域名做网站上海网站建设规范
  • 黑龙江省住房与城乡建设厅网站模板网站制作公司
  • 网站申请名称和域名南昌seo网站
  • 高端网站开发设计北京都有那些做网站的公司