React18新特性startTransition详解

 更新时间:2024年09月19日 14:11:29   作者:田本初  
React18的新特性startTransition主要是为了优化用户体验,通过标记低优先级的更新任务,如页面重渲染,使它们不会阻塞高优先级的紧急任务如用户输入响应,本文介绍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 机制会按照优先级调度任务并中断长时间的渲染过程,确保界面的交互性不会受到影响。

应用场景

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

到此这篇关于React18新特性 - startTransition的文章就介绍到这了,更多相关React18 startTransition内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用React-Router实现前端路由鉴权的示例代码

    使用React-Router实现前端路由鉴权的示例代码

    这篇文章主要介绍了使用React-Router实现前端路由鉴权的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • react路由跳转传参刷新页面后参数丢失的解决

    react路由跳转传参刷新页面后参数丢失的解决

    这篇文章主要介绍了react路由跳转传参刷新页面后参数丢失的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • React在定时器中无法获取状态最新值的问题

    React在定时器中无法获取状态最新值的问题

    这篇文章主要介绍了React在定时器中无法获取状态最新值的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • antd之RangePicker设置默认值方式

    antd之RangePicker设置默认值方式

    这篇文章主要介绍了antd之RangePicker设置默认值方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 从零开始搭建webpack+react开发环境的详细步骤

    从零开始搭建webpack+react开发环境的详细步骤

    这篇文章主要介绍了从零开始搭建webpack+react开发环境的详细步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • React如何实现全屏监听Esc键

    React如何实现全屏监听Esc键

    这篇文章主要介绍了React如何实现全屏监听Esc键,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • React+echarts (echarts-for-react) 实现中国地图及省份切换功能

    React+echarts (echarts-for-react) 实现中国地图及省份切换功能

    这篇文章主要介绍了React+echarts (echarts-for-react) 画中国地图及省份切换,有足够的地图数据,可以点击到街道,示例我只出到市级,本文结合实例代码给大家介绍的非常详细需要的朋友可以参考下
    2022-11-11
  • 如何对react hooks进行单元测试的方法

    如何对react hooks进行单元测试的方法

    这篇文章主要介绍了如何对react hooks进行单元测试的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 三分钟搞懂react-hooks及实例代码

    三分钟搞懂react-hooks及实例代码

    React Hooks是今年最劲爆的新特性真的毫不夸张。如果你也对react感兴趣,或者正在使用react进行项目开发,请抽出点时间阅读下此文
    2022-03-03
  • React实现虚拟滚动的三种思路详解

    React实现虚拟滚动的三种思路详解

    在​​web​​开发的过程中,或多或少都会遇到大列表渲染的场景,为了解决大列表造成的渲染压力,便出现了虚拟滚动技术,本文主要介绍虚拟滚动的三种思路,希望对大家有所帮助
    2024-04-04

最新评论