欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React18中startTransition與useTransition的使用

 更新時間:2025年05月20日 10:52:50   作者:jnsytgsyqjgm  
本文主要介紹了React18中startTransition與useTransition的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

React 18 引入了多項令人興奮的新特性,其中 startTransition 和 useTransition 是并發(fā)模式(Concurrent Mode)中的關(guān)鍵部分,旨在提升用戶體驗,通過區(qū)分緊急和非緊急任務(wù)來優(yōu)化應(yīng)用的響應(yīng)性。本文將詳細介紹這兩個特性及其在實際開發(fā)中的應(yīng)用。

一、并發(fā)模式與任務(wù)優(yōu)先級

在 React 18 之前,所有的狀態(tài)更新都是同步處理的,這意味著一旦狀態(tài)改變,組件就會立即重新渲染。這可能導致在處理大量數(shù)據(jù)或復雜視圖時,界面出現(xiàn)卡頓現(xiàn)象,影響用戶體驗。

并發(fā)模式的引入,使得 React 能夠以不同的優(yōu)先級處理狀態(tài)更新,從而保持界面的流暢性。緊急任務(wù)(如用戶輸入、點擊等)會被立即處理,而非緊急任務(wù)(如數(shù)據(jù)過濾、分頁切換等)則會被延遲處理。

React 18 引入的 startTransition 和 useTransition 旨在解決這類問題。它們允許開發(fā)者將一些非關(guān)鍵的狀態(tài)更新標記為過渡性更新,從而將其優(yōu)先級降低,讓 React 在主線程空閑時再去處理這些更新,確保關(guān)鍵的用戶交互(如點擊、滾動、輸入等)能夠得到及時響應(yīng),使應(yīng)用始終保持流暢和可用。

二、startTransition 的使用

(一)基本語法與用法

startTransition 是一個 API,用于標記某些狀態(tài)更新為非緊急任務(wù)。它允許開發(fā)者在不影響用戶交互的情況下,延遲處理一些低優(yōu)先級的更新。

import React, { useState, startTransition } from 'react';

const App = () => {
  // 用于存儲輸入框數(shù)據(jù)的狀態(tài)
  const [inputValue, setInputValue] = useState('');
  // 用于存儲處理后數(shù)據(jù)的狀態(tài)
  const [processedData, setProcessedData] = useState('');

  const handleInputChange = (e) => {
    const newData = e.target.value;
    setInputValue(newData);
    startTransition(() => {
      // 這里模擬對輸入數(shù)據(jù)進行一些耗時處理,比如拼接一個長字符串
      const processed = newData + ', processed and modified. This is a long text to simulate a heavy operation. '.repeat(1000);
      setProcessedData(processed);
    });
  };

  return (
    <div>
      <input type="text" onChange={handleInputChange} placeholder="Enter something" />
      <p>Input: {inputValue}</p>
      <p>Processed Data: {processedData}</p>
    </div>
  );
};

export default App;

在這個示例中,當用戶在輸入框中輸入內(nèi)容時,inputValue 會立即更新以反映用戶輸入。同時,startTransition 會將對 processedData 的更新操作標記為過渡性更新。這意味著,即使處理 processedData 的過程可能比較耗時(如模擬的長字符串拼接),用戶界面在這個過程中仍然可以響應(yīng)其他操作,比如繼續(xù)輸入文本,而不會出現(xiàn)卡頓現(xiàn)象,直到主線程有空閑時間來處理 processedData 的更新并在界面上顯示最終結(jié)果。

(二)內(nèi)部工作原理

當 startTransition 被調(diào)用時,React 會將傳入的更新函數(shù)放入一個低優(yōu)先級的任務(wù)隊列中。它會首先處理完當前正在進行的高優(yōu)先級任務(wù)(如用戶的即時交互操作對應(yīng)的更新),然后在主線程有空閑時間時,才會從低優(yōu)先級任務(wù)隊列中取出這些過渡性更新任務(wù)并執(zhí)行。這樣就有效地避免了因大量數(shù)據(jù)更新或復雜計算導致的界面卡頓,使得應(yīng)用在更新過程中依然能夠響應(yīng)用戶的其他操作。

三、useTransition 的使用

(一)基本語法與返回值

useTransition 是一個 React Hook,它在函數(shù)組件中使用。其語法如下:

import { useTransition } from'react';
const [isPending, startTransition] = useTransition();

它返回一個包含兩個元素的數(shù)組。第一個元素 isPending 是一個布爾值,表示當前是否有過渡性更新正在進行。第二個元素 startTransition 與前面提到的全局 startTransition 函數(shù)功能相同,用于標記狀態(tài)更新為過渡性更新。

(二)在組件中的應(yīng)用示例

以下是一個更完整的示例,展示了 useTransition 在一個搜索組件中的應(yīng)用:

import React, { useState, useTransition } from "react";
import { Input, Spin, List } from "antd";

const { Search } = Input;

// 生成 1000 條模擬數(shù)據(jù)
const mockData = [];
for (let i = 1; i <= 1000; i++) {
  mockData.push({
    id: i,
    name: `Item ${i}`,
    description: `This is the description of item ${i}`
  });
}

const App = () => {
  // 搜索關(guān)鍵詞狀態(tài)
  const [searchQuery, setSearchQuery] = useState("");
  // 搜索結(jié)果狀態(tài)
  const [searchResults, setSearchResults] = useState(mockData);
  // 通過 useTransition 獲取 startTransition 和 isPending
  const [isPending, startTransition] = useTransition();

  const handleSearch = (value) => {
    setSearchQuery(value);
    startTransition(() => {
      // 模擬異步搜索操作
      const newResults = mockData.filter((item) =>
        item.name.toLowerCase().includes(value.toLowerCase())
      );
      setSearchResults(newResults);
    });
  };

  return (
    <div>
      <Search
        placeholder="Search..."
        onChange={(e) => handleSearch(e.target.value)}
        enterButton
      />
      {isPending && (
        <Spin
          style={{
            marginTop: 16,
            textAlign: "center"
          }}
        />
      )}
      <List
        bordered
        dataSource={searchResults}
        renderItem={(item) => (
          <List.Item key={item.id}>
            <List.Item.Meta
              title={item.name}
              description={item.description}
            />
          </List.Item>
        )}
      />
    </div>
  );
};

export default App;

在上述代碼中,當用戶在搜索框中輸入內(nèi)容并執(zhí)行搜索時,會在模擬的異步搜索操作中過濾數(shù)據(jù),并根據(jù) useTransition 的狀態(tài)顯示 Spin 加載組件或搜索結(jié)果列表。這樣在搜索大數(shù)據(jù)量時,能夠利用 useTransition 來優(yōu)化用戶體驗,避免界面卡頓。

四、應(yīng)用場景

startTransition 和 useTransition 非常適合用于以下場景:

  • 搜索和過濾:當用戶輸入關(guān)鍵詞進行搜索或過濾時,可以立即更新輸入框的值,并延遲更新搜索結(jié)果。
  • 復雜視圖:在處理包含大量數(shù)據(jù)的復雜視圖時,可以使用 startTransition 延遲更新,以保持界面的流暢性。
  • 分頁切換:在分頁切換時,可以立即更新頁碼,并延遲加載新頁面的數(shù)據(jù)。

五、避免過度使用與性能平衡

雖然 startTransition 和 useTransition 能夠有效提升用戶體驗,但也不能過度依賴。過多的過渡性更新可能會導致低優(yōu)先級任務(wù)隊列積壓,最終影響整體性能。在設(shè)計應(yīng)用時,需要合理評估哪些狀態(tài)更新是真正適合標記為過渡性的,并且結(jié)合其他性能優(yōu)化策略,如數(shù)據(jù)分頁、緩存機制、虛擬列表等,以達到最佳的性能平衡。

到此這篇關(guān)于React18中startTransition與useTransition的使用的文章就介紹到這了,更多相關(guān)React18 startTransition useTransition內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中 Zustand狀態(tài)管理庫的使用詳解

    React中 Zustand狀態(tài)管理庫的使用詳解

    Zustand?是一個非常輕量、簡潔的狀態(tài)管理庫,旨在為 React 提供簡便且高效的狀態(tài)管理,相比于 Redux 或 Context API,Zustand 具有更簡潔、靈活和易于理解的優(yōu)點,感興趣的朋友一起看看吧
    2024-12-12
  • 用react-redux實現(xiàn)react組件之間數(shù)據(jù)共享的方法

    用react-redux實現(xiàn)react組件之間數(shù)據(jù)共享的方法

    這篇文章主要介紹了用react-redux實現(xiàn)react組件之間數(shù)據(jù)共享的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • 淺談React組件在什么情況下會重新渲染

    淺談React組件在什么情況下會重新渲染

    當我們使用React編寫組件時,組件的重新渲染是一個重要的概念,本文主要介紹了React組件在什么情況下會重新渲染,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • React實現(xiàn)表單提交防抖功能的示例代碼

    React實現(xiàn)表單提交防抖功能的示例代碼

    在 React 應(yīng)用中,防抖(Debounce)技術(shù)可以有效地限制函數(shù)在短時間內(nèi)的頻繁調(diào)用,下面我們就來看看如何使用Lodash庫中的debounce函數(shù)實現(xiàn)React表單提交中實現(xiàn)防抖功能吧
    2024-01-01
  • 每天學習一個hooks?useMount

    每天學習一個hooks?useMount

    這篇文章主要為大家介紹了每天學習一個hooks?useMount,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • 利用CDN加速react webpack打包后的文件詳解

    利用CDN加速react webpack打包后的文件詳解

    下面小編就為大家分享一篇利用CDN加速react webpack打包后的文件詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • React+Antd修改Table組件滾動條樣式的操作代碼

    React+Antd修改Table組件滾動條樣式的操作代碼

    這篇文章主要介紹了React+Antd修改Table組件滾動條樣式的操作代碼,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • react組件傳值的四種方法

    react組件傳值的四種方法

    本文主要介紹了react組件傳值的四種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • React?模式之純組件使用示例詳解

    React?模式之純組件使用示例詳解

    這篇文章主要為大家介紹了React?模式之純組件使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • React函數(shù)式組件與類組件的不同你知道嗎

    React函數(shù)式組件與類組件的不同你知道嗎

    這篇文章主要為大家詳細介紹了React函數(shù)式組件與類組件的不同,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03

最新評論