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

【React】React18新特性 - startTransition

前言

React 18 引入了 startTransition,这是 Concurrent Mode「并发特性」 中的一部分,主要用于标记那些不需要立即响应的 低优先级 更新,为它们分配不同的优先级,低优先级任务会延迟处理,从而保持界面交互的流畅性。

作用

startTransition 会标记某些更新为非紧急的。React 会为这些标记的任务分配较低的优先级,保证用户界面的紧急更新(如输入框的输入响应)不会因为其他较大开销的更新而被阻塞,从而提升用户体验。

  • 紧急任务:用户的输入、点击、表单操作等需要立即响应的操作。
  • 非紧急任务:状态的更新、页面的重新渲染等不需要立即更新完成的任务,例如列表的过滤、分页的切换等。

使用

useTransition 返回 isPending 和 startTransition 函数:

  • isPending:表示低优先级任务是否正在处理,通常可以用来显示一个加载指示器。
  • startTransition:用于标记低优先级的更新。
const [isPending, startTransition] = useTransition();

startTransition(() => {
  // 此处的更新会被标记为低优先级
  setState(newValue);
});

工作原理

1. Lanes

通过 Lanes 机制实现优先级调度(每个更新任务都会被分配到不同的 Lane 中,根据其优先级进行调度)。

使用 startTransition 时,React 会将这个任务分配到一个较低优先级的 Lane 中,这样它不会阻塞高优先级的任务(如用户的交互)。
如果高优先级任务出现(例如用户在表单中输入新的内容),React 可以暂停低优先级任务,先处理紧急任务,再在空闲时恢复低优先级任务。

2. Fiber Reconciler

通过 Fiber Reconciler 处理更新任务。当 startTransition 标记某个任务为低优先级后,Fiber 机制会按照优先级调度任务并中断长时间的渲染过程,确保界面的交互性不会受到影响。

应用场景

  • 搜索和过滤后大规模的数据渲染
  • 复杂视图

http://www.kler.cn/news/310061.html

相关文章:

  • vue-ts-demo
  • 【C-项目】网盘(一期,无限进程版)
  • 什么是数据治理?如何保障数据质量安全
  • 大舍传媒:尼日利亚传统新闻媒体宣传助力新兴行业蓬勃发展
  • 百收SEO蜘蛛池
  • Spring Boot 项目的 pom.xml 中,groupId、artifactId 等信息要如何定义?——定义规则及案例
  • 渗透测试综合靶场 DC-1 通关详解
  • (PySpark)RDD实验实战——求商品销量排行
  • 教师薪酬管理系统的设计与实现
  • Springboot与minio:
  • 《C++魔法:零开销实现抽象工厂模式》
  • LeetCode 滑动窗口 滑动子数组的美丽值
  • Java迭代器Iterator和Iterable有什么区别?
  • 2024 ccpc 网络赛题解
  • SEO之页面优化(一-页面标题2)
  • Java操作数栈分析
  • 【JAVA基础】实现Tomcat基本功能
  • PyQt5-QCheckBox-开关按钮
  • Maven详细介绍
  • 【postgres】笔记
  • 重修设计模式-结构型-适配器模式
  • Doker学习笔记--黑马
  • Unity从2018.1版本开始,可以采用内置JSON进行存档和读档
  • windows C++ 并行编程-异步代理库概述
  • git 删除远程分支的几种写法
  • 基于stm32的四旋翼无人机控制系统设计系统设计与实现
  • vs2022配置opencv==4.9.0(C++)
  • 所有用贪心的算法和所有用动态规划(dp)的算法合集
  • Linux C高级 day1
  • 【线程】线程的控制