主流前端框架实现原理

本文深入探讨了主流前端框架的更新机制,包括节点级的Svelte和SOLID、组件级的Vue以及应用级的React。节点级框架通过预编译实现细腻度更新,监听状态变化并直接调用方法更新视图。应用级框架如React利用虚拟DOM技术,对比新旧DOM树来优化更新。而Vue则在状态更新后仅生成变化部分的DOM树,并引入预编译提高效率。这些框架的核心都是UI=f(state),根据状态驱动视图的渲染。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主流前端框架都遵循组件化开发模式,根据更新粒度可以分为应用级、组件级和节点级。他们的实现原理均为UI=f(state)

即框架内部的运行机制根据状态渲染视图

应用级代表:React

组件级代表:Vue

节点级代表:Svelte、SOLID

一、 节点级更新框架原理

  1. 预编译:将状态变化可能导致的节点变化编译为具体方法
  2. 细腻度更新
    1. 监听状态变化:采用发布订阅者模式,创建一个状态之后,会为状态维护一张“订阅该状态变化的表”,所有需要监听该状态的函数都会在该状态表中注册,每当状态变化,都会遍历这张表。
    2. 当监听导致状态变化直接调用具体方法改变对应视图

二、 应用级更新框架原理

采用虚拟DOM技术。首屏渲染时,React会根据应用的树结构创建一颗对应的虚拟DOM树,当状态更新后,React生成一颗完整的虚拟DOM树,新生成的每个节点会与之前的虚拟DOM树的同级节点进行比较,如果存在差异,则记录该差异,然后将记录的不一致渲染到视图上。

二、 组件级更新框架原理

Vue在状态更新后,不生成整个虚拟DOM树,只生成发生改变的DOM树。

主要使用细腻度更新和虚拟DOM,Vue3中引入了预编译

参考:

『货很干』主流前端框架的实现原理,懂完了你_哔哩哔哩_bilibili

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值