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

一文搞懂?React?18?中的?useTransition()?與?useDeferredValue()

 更新時間:2022年09月12日 08:49:04   作者:github_is_geeksKai  
這篇文章主要介紹了一文搞懂?React?18?中的?useTransition()與useDeferredValue(),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言

React 18 引入了一個關(guān)鍵的新概念,稱為“Concurrent”。

并發(fā)涉及同時執(zhí)行多個狀態(tài)更新,這可以說是 React 18 中最重要的特性。除了并發(fā)之外,React 18 還引入了兩個新的鉤子,稱為 useTransition() 和 useDeferredValue() 鉤子。

它們都有助于降低狀態(tài)更新的優(yōu)先級,但問題是,何時應(yīng)該使用它們?

什么是Concurrent React?

根據(jù)官方 React18 Docs,并發(fā) React 是:

一種新的幕后機制,使 React 能夠同時準備多個版本的 UI。您可以將并發(fā)視為一個實現(xiàn)細節(jié)——它的價值在于它的特性。

并發(fā)可以定義為同時執(zhí)行大量任務(wù)的能力。并發(fā)并不是一個特性。相反,它是一個幕后功能,它允許 React 同時(并發(fā)地)準備許多 UI 實例。 React 以一種對開發(fā)人員隱藏實現(xiàn)細節(jié)的方式創(chuàng)建 API。 React 創(chuàng)建者認為,React 開發(fā)人員應(yīng)該專注于 React 功能將如何幫助他們實現(xiàn)他們希望為客戶提供的用戶體驗,并且 React 將弄清楚如何提供這種體驗。

Concurrent React 不僅僅是一個實現(xiàn)細節(jié)。相反,它是更新框架核心渲染架構(gòu)的重大升級。因此,了解它在 React 18 中是如何工作的至關(guān)重要。

設(shè)置項目

對于本文,我創(chuàng)建了一個 Github 存儲庫,在其中我構(gòu)建了一個簡單的演示產(chǎn)品應(yīng)用程序,允許用戶通過輸入產(chǎn)品編號來查看產(chǎn)品。首先,您必須克隆包含所有項目啟動文件的 Github 存儲庫。要克隆 Github 存儲庫,請轉(zhuǎn)到終端并運行以下命令:

git clone https://github.com/geekskai/react18-feature.git

完成克隆過程后,轉(zhuǎn)到項目文件夾,在代碼編輯器上打開它,轉(zhuǎn)到編輯器終端,然后通過運行npm install 或安裝腳本和依賴項 yarn install然后,要啟動項目,請執(zhí)行 npm start

應(yīng)用程序啟動后,它應(yīng)該如下所示:

實現(xiàn) useTransition()

當您第一次輸入產(chǎn)品編號以獲取product時,您會注意到它幾乎會立即更新,即使它是一個包含 10,000 項要瀏覽的超長列表。

現(xiàn)在,當您轉(zhuǎn)到 Chrome 瀏覽器的開發(fā)人員工具部分,轉(zhuǎn)到性能選項卡,打開 CPU 節(jié)流并將 CPU 速度降低 4 倍時,問題就開始了。

如果您現(xiàn)在在降低 CPU 速度后嘗試輸入產(chǎn)品編號,您會注意到更新變得更慢且卡頓明顯。甚至整個界面看起來和感覺都很遲鈍,尤其是輸入字段,現(xiàn)在在我們輸入和刪除時感覺沒有響應(yīng)。 而這絕對不是一個好的用戶體驗。

你看不到我在打字,但界面響應(yīng)很慢,如上所示。甚至在 React18 之前,一個標準的解決方案不是一次處理 10,000 個項目或產(chǎn)品(在我們的例子中)。您可以使用分頁或任何其他技術(shù),或者在服務(wù)器端而不是客戶端進行過濾。這些都是您在遇到此類問題時可以考慮的所有可能的解決方案。

但是,如果您需要在客戶端執(zhí)行這種操作,即在您的客戶端代碼上,那么使用 React18,您現(xiàn)在擁有一些工具,可以通過延遲一些狀態(tài)更新操作來為用戶提供更好的感知性能通過告訴 React 一些更新操作比其他操作具有更高的優(yōu)先級。這就是 React 18 引入的并發(fā)以及相關(guān)的鉤子和函數(shù)背后的想法。

useTransition() 告訴 React 一些狀態(tài)更新具有較低的優(yōu)先級,即每個其他狀態(tài)更新或 UI 渲染觸發(fā)器具有較高的優(yōu)先級。當我們調(diào)用 useTransition() 時,我們得到一個包含兩個元素的數(shù)組:一個 isPending 布爾值,它指示低優(yōu)先級狀態(tài)更新是否仍處于掛起狀態(tài),以及一個 startTransition() 函數(shù),您可以將狀態(tài)更新包裝起來告訴 React這是一個低優(yōu)先級的更新。

查看如何使用 useTransition() 鉤子。首先,轉(zhuǎn)到 App.js 文件并編輯代碼,如下所示:

function App() {
  const [isPending, startTransition] = useTransition();
  const [filterTerm, setFilterTerm] = useState('');
  
  const filteredProducts = filterProducts(filterTerm);
  
  function updateFilterHandler(event) {
    startTransition(() => {
      setFilterTerm(event.target.value);
    });
  }
 
  return (
    <div id="app">
      <input type="text" onChange={updateFilterHandler} />
      <ProductList products={filteredProducts} />
    </div>
  );
}

因為 startTransition() 包裝了 setFilterTerm() 狀態(tài)更新函數(shù),所以 React 給這個狀態(tài)更新代碼一個較低的優(yōu)先級。這可確保輸入字段保持響應(yīng)并立即響應(yīng)演示應(yīng)用程序中的擊鍵。如果未使用 useTransition(),應(yīng)用程序可能會變得無響應(yīng),尤其是在速度較慢的設(shè)備上。當您輸入產(chǎn)品編號時,您會看到代碼現(xiàn)在響應(yīng)速度更快且延遲更少,即使 CPU 已減慢 4 倍。您可以在您的系統(tǒng)上嘗試此操作并查看結(jié)果。

但是,您不應(yīng)該開始使用 startTransition 來結(jié)束所有狀態(tài)更新。僅當您的用戶界面較慢時才使用它,尤其是在舊設(shè)備上,或者在您沒有其他解決方案可使用的情況下。這是因為它占用了額外的性能。

isPending 是做什么的?

isPending 告訴您當前是否有一些狀態(tài)更新仍處于待處理狀態(tài)(React 尚未執(zhí)行,并且優(yōu)先級較低。您可以使用 isPending 更新 UI 以在等待主要狀態(tài)時顯示一些后備內(nèi)容更新完成。

我們可以在 App.ts 文件中的以下代碼中看到這一點:

return (
    <div id="app">
      <input type="text" onChange={updateFilterHandler} />
      {isPending && <p style={{color: 'white'}}>Updating list..</p>}
      <ProductList products={filteredProducts} />
    </div>
  );
}

實現(xiàn)代碼后,您應(yīng)該能夠在運行應(yīng)用程序時看到如下內(nèi)容:

因此,這也是您在使用 useTransition() 時可以使用的功能。另外,請注意觀察實現(xiàn) useTransition() 功能后它的響應(yīng)速度有多快。

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

相關(guān)文章

  • React中DOM事件和狀態(tài)介紹

    React中DOM事件和狀態(tài)介紹

    這篇文章主要介紹了React中DOM事件和狀態(tài)介紹,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-08-08
  • 淺談React + Webpack 構(gòu)建打包優(yōu)化

    淺談React + Webpack 構(gòu)建打包優(yōu)化

    本篇文章主要介紹了淺談React + Webpack 構(gòu)建打包優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • React 添加引用路徑時如何使用@符號作為src文件

    React 添加引用路徑時如何使用@符號作為src文件

    這篇文章主要介紹了React 添加引用路徑時如何使用@符號作為src文件,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 如何在 React 中調(diào)用多個 onClick 函數(shù)

    如何在 React 中調(diào)用多個 onClick 函數(shù)

    這篇文章主要介紹了如何在React中調(diào)用多個onClick函數(shù),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • React?Native項目設(shè)置路徑別名示例

    React?Native項目設(shè)置路徑別名示例

    這篇文章主要為大家介紹了React?Native項目設(shè)置路徑別名實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • 解決React報錯The?tag?is?unrecognized?in?this?browser

    解決React報錯The?tag?is?unrecognized?in?this?browser

    這篇文章主要為大家介紹了解決React報錯The?tag?is?unrecognized?in?this?browser示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • React中組件通信的幾種主要方式

    React中組件通信的幾種主要方式

    React知識中一個主要內(nèi)容便是組件之間的通信,以下列舉幾種常用的組件通信方式,通過代碼示例介紹的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-10-10
  • Ant Design與Ant Design pro入門使用教程

    Ant Design與Ant Design pro入門使用教程

    Ant Design 是一個服務(wù)于企業(yè)級產(chǎn)品的設(shè)計體系,組件庫是它的 React 實現(xiàn),antd 被發(fā)布為一個 npm 包方便開發(fā)者安裝并使用,這篇文章主要介紹了Ant Design與Ant Design pro入門,需要的朋友可以參考下
    2023-12-12
  • React無限滾動加載列表組件的封裝實現(xiàn)

    React無限滾動加載列表組件的封裝實現(xiàn)

    無限下拉加載技術(shù)是用戶在大量成塊的內(nèi)容面前一直滾動查看,本文主要介紹了React無限滾動加載列表組件的封裝實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • React?Hook?四種組件優(yōu)化總結(jié)

    React?Hook?四種組件優(yōu)化總結(jié)

    這篇文章主要介紹了React?Hook四種組件優(yōu)化總結(jié),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價孩子,需要的朋友可以參考一下
    2022-07-07

最新評論