对为什么react需要时间分片,vue3不需要的浅学习

1、时间分片

时间分片指在让应用在cpu进行大量计算时也能与用户交互,但时间分片只能对大量cpu计算进行优化,无法优化复杂DOM操作,因为要确保用户正在操作的界面是最新。

web卡顿的场景:

1、cpu计算量不大,但dom操作非常复杂(比如说你向页面插入了十万个节点)。这种场景下不管做不做时间分片,页面都会很卡。

2、cpu计算量非常大。理论上时间分片在这种场景里会有较大收益,但是人机交互研究表明,除了动画场景外,大部分用户不会觉得 10 毫秒和 100 毫秒有很大区别。也就是说,时间分片只在 CPU 需要连续计算 100 毫秒以上的情况下才有较大收益。

2、react需要时间分片

React 16引入了Fiber重构,其目的是为了实现虚拟DOM的优先级级别和中断重新开始的渲染过程,这被称为“时间分片”。Fiber框架通过分层调度、暂停和重用执行树的部分来提高其性能,这样可以在浏览器有时间处理用户交互或动画的时候动态地调度工作。

Fiber的引入为React提供了以下优势:

可中断的渲染- 优先级渲染(比如,用户交互比如滚动优先于动画)- 可复用的渲染(比如,在使用用户界面时可以在后台继续渲染其他部分)

这些优点使得React应用程序能够更加高效地更新用户界面,并且不会导致之前版本的“闪烁”问题。

解决方案:

React 16及以上版本会自动使用Fiber框架,无需用户进行任何操作。如果你正在使用React 15或更早的版本,你需要升级到React 16或更高版本以获得Fiber的好处

import React from 'react';
import ReactDOM from 'react-dom';class MyComponent extends React.Component {// ...render() {// 使用新的Fiber渲染算法渲染组件return (<div>{/* ... */}</div>);}
}ReactDOM.render(<MyComponent />, document.getElementById('root'));

在这个例子中,React 16使用Fiber重构实现了虚拟DOM的更新,使得用户界面的渲染能够被中断和重新开始,从而提高了性能。

2.1关于Fiber框架学习。

参考:https://blog.51cto.com/u_11887782/5782954

3、vue3不需要时间分片

Vue 3 不需要时间分片(time slicing)主要是因为它的核心渲染机制和性能优化策略已经足够高效,能够在大多数情况下提供流畅的用户体验。以下是详细的原因:

3.1、编译器优化

Vue 3 引入了一个全新的编译器,能够生成更高效的渲染函数。这个编译器在编译过程中进行了一系列优化,例如:

  • 静态提升:将不变的节点提升为常量,只在初次渲染时计算一次。
  • 预字符串化:将静态内容直接转化为字符串,减少了运行时的开销。
  • 缓存事件处理程序:避免了不必要的重新绑定。

这些优化措施大大减少了 Vue 3 在更新 DOM 时的计算量,使得渲染过程更加高效。

3.2.、响应式系统的改进

Vue 3 使用了基于代理的响应式系统,替代了 Vue 2 中基于 Object.defineProperty 的实现。新的响应式系统更加高效,具备以下优点:

  • 精细的依赖追踪:只追踪实际使用的属性,避免了不必要的依赖收集。
  • 懒惰计算:仅在需要时才计算依赖,减少了计算量。

这些改进使得 Vue 3 能够更快速地响应数据变化,从而减少了渲染开销。

3.3、虚拟 DOM 和 Diff 算法的优化

Vue 3 对虚拟 DOM 及其 diff 算法进行了优化,使得差异计算更加高效:

  • 静态标记:编译期间标记静态节点,跳过不变的部分。
  • 块级优化:将动态节点分块,只对发生变化的块进行更新。

这些优化措施减少了 DOM 更新的频率和范围,提高了整体渲染性能。

3.4、单次异步队列

Vue 3 的更新机制基于单次异步队列(single asynchronous queue),它确保在同一事件循环中只进行一次批量更新。这种方式减少了不必要的重复计算和 DOM 操作,使得更新过程更加高效。

3.5、自动批处理

Vue 3 实现了自动批处理机制,在同一个事件循环中对多次数据更新进行合并,从而减少了渲染次数。这种机制在避免频繁重绘的同时,保证了界面的流畅性。

3.6、现代浏览器的性能

现代浏览器的性能已经得到了极大的提升,尤其是在处理 JavaScript 和 DOM 操作方面。Vue 3 的优化能够充分利用这些性能改进,从而在绝大多数情况下不需要时间分片。

3.7总结

Vue 3 通过编译器优化、响应式系统改进、虚拟 DOM 和 Diff 算法优化、单次异步队列、自动批处理等技术手段,大幅提升了渲染效率和性能。再加上现代浏览器的性能提升,使得 Vue 3 能够在大多数情况下提供流畅的用户体验,而无需借助时间分片等复杂的技术。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/44276.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

人工智能算法工程师(中级)课程1-Opencv视觉处理之基本操作与代码详解

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能算法工程师(中级)课程1-Opencv视觉处理之基本操作与代码详解。OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习软件库。它提供了各种视觉处理函数&am…

Redis为什么变慢了?一文讲透如何排查Redis性能问题

Redis 作为优秀的内存数据库&#xff0c;其拥有非常高的性能&#xff0c;单个实例的 OPS 能够达到 10W 左右。但也正因此如此&#xff0c;当我们在使用 Redis 时&#xff0c;如果发现操作延迟变大的情况&#xff0c;就会与我们的预期不符。 你也许或多或少地&#xff0c;也遇到…

以太网中的各种帧结构

帧结构&#xff08;Ethernet Frame Structure&#xff09;介绍 以太网信号帧结构&#xff08;Ethernet Signal Frame Structure&#xff09;&#xff0c;有被称为以太网帧结构&#xff0c;一般可以分为两类 —— 数据帧和管理帧。 按照 IEEE 802.3&#xff0c;ISO/IEC8803-3 …

短视频矩阵管理系统:如何提升内容质量,帮助企业获客?

在数字化营销蓬勃发展的今天&#xff0c;短视频已成为企业推广的重要阵地。然而&#xff0c;如何高效管理短视频内容&#xff0c;提升内容质量&#xff0c;进而帮助企业精准获客&#xff0c;成为企业亟待解决的问题。短视频矩阵管理系统应运而生&#xff0c;以其强大的功能和灵…

TCP/IP协议超时重传,以及应用层超时重传一文详解

很多人会有这样的疑问 TCP/IP协议内置了超时重传的功能&#xff0c;那为什么连接完全断开或超时时&#xff0c;应用层代码段还会进行重传处理呢&#xff1f; TCP协议的重传机制 客户端 服务器| ||---- 数据段1 --…

编程范式之并发编程

目录 前言1. 并发编程的定义2. 并发编程的特点2.1 任务交替执行2.2 状态共享与同步2.3 并行执行 3. 并发编程的适用场景3.1 高性能计算3.2 I/O 密集型应用3.3 实时系统 4. 并发编程的优点4.1 提高资源利用率4.2 缩短响应时间4.3 提高系统吞吐量 5. 并发编程的缺点5.1 编程复杂性…

硬盘模式vmd怎么改ahci_电脑vmd改ahci模式详细步骤

最近有很多网友问&#xff0c;我新买的电脑安装原版win10或win11找不到驱动器呀&#xff0c;进入第三方pe又找不到硬盘&#xff0c;找到硬盘安装后又出现安装蓝屏的情况&#xff0c;新机器怎么回事呀&#xff1f;这位网友内心有点崩溃&#xff0c;不知道啥原因。其实这些都是由…

初识c++(类与对象——上)

一、类的定义 1、类定义格式 • class为定义类的关键字&#xff0c;Stack为类的名字&#xff0c;{}中为类的主体&#xff0c;注意类定义结束时后面分号不能省 略。类体中内容称为类的成员&#xff1a;类中的变量称为类的属性或成员变量; 类中的函数称为类的方法或 者成员函…

损失函数 - Transformer教程

在人工智能和深度学习的领域&#xff0c;Transformer模型已经成为了非常流行的选择。而在Transformer模型的训练过程中&#xff0c;损失函数扮演了至关重要的角色。今天&#xff0c;我们就来深入探讨一下什么是损失函数&#xff0c;以及它在Transformer中的应用。 什么是损失函…

【Node.js安装教程】

Node.js安装教程 第一步&#xff1a;下载 下载链接&#xff1a;https://nodejs.org/zh-cn 第二步&#xff1a;安装 **方法一&#xff1a;**建议安装在默认路径 方法二&#xff1a;如果不是默认安装路径可能会出现一系列问题&#xff1a;这时可以选择卸载重装或者配置环境变量…

kotlin数据类型

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 Kotlin基本数值类型 基本数据类型包括 Byte、Short、Int、Long、Float、Double 整数类型 类型位宽最小值最大…

安卓微信8.0之后如何利用缓存找回的三天之前不可见的朋友圈图片

安卓微信8.0之后如何利用缓存找回的三天之前不可见的朋友圈图片 复习了下安卓程序的知识&#xff0c;我们会了解到&#xff0c;安卓程序清楚数据的时候有两个选项 一个是清除全部数据一个是清除缓存。 清除全部数据表示清除应用数据缓存。 对于安卓微信8.0之后而言&#xff0…

OTP防重放攻击

OTP本意是一次性口令&#xff0c;比如邮箱验证码&#xff0c;短信验证码&#xff0c;或者根据totp或者hotp生成的默认30秒一变的6位数字。 不过开发者要注意&#xff0c;必须要在验证成功后失效那个验证码&#xff0c;不然就会导致重放攻击。 对于邮箱验证码&#xff0c;服务器…

彻底开源,免费商用,上海AI实验室把大模型门槛打下来

终于&#xff0c;业内迎来了首个全链条大模型开源体系。 大模型领域&#xff0c;有人探索前沿技术&#xff0c;有人在加速落地&#xff0c;也有人正在推动整个社区进步。 就在近日&#xff0c;AI 社区迎来首个统一的全链条贯穿的大模型开源体系。 虽然社区有LLaMA等影响力较大…

从 ArcMap 迁移到 ArcGIS Pro

许多 ArcMap 用户正在因 ArcGIS Pro 所具有的现代 GIS 桌面工作流优势而向其迁移。 ArcGIS Pro 与其余 ArcGIS 平台紧密集成&#xff0c;使您可以更有效地共享和使用内容。 它还将 2D 和 3D 组合到一个应用程序中&#xff0c;使您可以在同一工程中使用多个地图和多个布局。 Arc…

【C++杂货铺】C++11新特性

目录 &#x1f308; 前言&#x1f308; &#x1f4c1; C11介绍 &#x1f4c1; 统一初始化列表 &#x1f4c1; 声明 &#x1f4c2; auto &#x1f4c2; decltype &#x1f4c2; 返回类型后置 &#x1f4c2; 范围for &#x1f4c2; 模板别名 &#x1f4c2; nullptr &#x1…

服务器使用PC作为代理访问外网

1、PC上启动代理&#xff0c;比如nginx 下载nginx&#xff1a;http://nginx.org/en/download.html 修改配置文件&#xff0c;在conf下&#xff1a; http {include mime.types;default_type application/octet-stream;sendfile on;keepalive_timeout 65;server…

六、 SpringBoot 配置⽂件 ★ ✔

六、 SpringBoot 配置⽂件 本节⽬标1. 配置⽂件作⽤2. 配置⽂件快速⼊⼿3. 配置⽂件的格式4. properties 配置⽂件说明4.1 properties 基本语法4.2 读取配置⽂件4.3 properties 缺点分析 5. yml 配置⽂件说明5.1 yml 基本语法5.2 yml 使⽤进阶5.2.1 yml 配置不同数据类型及 nul…

昇思25天学习打卡营第17天|文本解码原理--以MindNLP为例

文本解码就是根据当前已经输入的内容不断地预测下一个词&#xff0c;前期通过大量的文本文章等输入&#xff0c;让模型学习好以后&#xff0c;根据已学习的内容&#xff0c;不断预测下一个词。就像鹦鹉学舌一样你不断的叫他说你好大帅哥&#xff0c;你好大帅哥。后面某一天&…

好用的源代码加密软件有哪些?5款源代码防泄密软件推荐

源代码作为软件产品的核心组成部分&#xff0c;其安全性直接关系到整个软件系统的安全。源代码的泄露可能导致企业的技术秘密暴露&#xff0c;商业竞争力下降&#xff0c;甚至可能引发经济损失和法律责任问题。因此&#xff0c;对源代码进行加密保护&#xff0c;已经成为企业不…