91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React組件狀態下移和內容提升怎么實現

發布時間:2022-11-28 09:27:49 來源:億速云 閱讀:79 作者:iii 欄目:開發技術

本篇內容介紹了“React組件狀態下移和內容提升怎么實現”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

前言

兩個簡單實用的優化組件渲染性能的方法:

  • 狀態下移

  • 內容提升

在講解這兩種方法之前,我們需要先手動創建一個有嚴重渲染性能的組件,如下所示:

import { useState } from 'react';

export default function App() {
  let [color, setColor] = useState('red');
  return (
    <div>
      <input value={color} onChange={(e) => setColor(e.target.value)} />
      <p style={{ color }}>Hello, world!</p>
      <ExpensiveTree />
    </div>
  );
}

function ExpensiveTree() {
  let now = performance.now();
  while (performance.now() - now < 100) {
    // Artificial delay -- do nothing for 100ms
  }
  return <p>I am a very slow component tree.</p>;
}

很顯然,當 App 組件內的狀態發生了改變,ExpensiveTree 組件會 re-render, 事實上 ExpensiveTree 組件的 props、state 并未發生改變,這并不是我們期望的結果,下面將提供兩種簡單的方法,提升組件渲染的性能;

狀態下移

export default function App() {
  let [color, setColor] = useState('red');
  return (
    <div>
      <input value={color} onChange={(e) => setColor(e.target.value)} />
      <p style={{ color }}>Hello, world!</p>
      <ExpensiveTree />
    </div>
  );
}

我們可以看到以上 ExpensiveTree 組件并不依賴 App 組件內部的狀態,因此我們是否可以考慮,將依賴 color 的元素抽離到一個依賴 color 的組件中呢?
下面是實踐后的代碼:

export default function App() {
  return (
    <>
      <Form />
      <ExpensiveTree />
    </>
  );
}

function Form() {
  let [color, setColor] = useState('red');
  return (
    <>
      <input value={color} onChange={(e) => setColor(e.target.value)} />
      <p style={{ color }}>Hello, world!</p>
    </>
  );
}

此時,將依賴 color 的元素提取到了 Form 組件中,Form 組件內部的狀態不再影響 ExpensiveTree 組件的渲染,問題便得到了解決

內容提升

export default function App() {
  let [color, setColor] = useState('red');
  return (
    <div style={{ color }}>
      <input value={color} onChange={(e) => setColor(e.target.value)} />
      <p>Hello, world!</p>
      <ExpensiveTree />
    </div>
  );
}

以上情況是高開銷組件 ExpensiveTree 的父節點依賴 color,此時顯然狀態下移是行不通的,但是還有另外一種辦法:

export default function App() {
  return (
    <ColorPicker>
      <p>Hello, world!</p>
      <ExpensiveTree />
    </ColorPicker>
  );
}

function ColorPicker({ children }) {
  let [color, setColor] = useState("red");
  return (
    <div style={{ color }}>
      <input value={color} onChange={(e) => setColor(e.target.value)} />
      {children}
    </div>
  );
}

此時和狀態提升是完全相反的,將依賴 color 的元素提升到了 ColorPicker 組件中,而不依賴 color 的元素以 children prop 的形式傳入了 ColorPicker ,當組件內部的狀態改變時:

  • ColorPicker 會重新渲染但是它仍然保存著

  • ColorPicker 的 children 屬性未變化 React 并不會訪問那棵子樹。 因此,ExpensiveTree不會重新渲染。

“React組件狀態下移和內容提升怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

延边| 含山县| 晋州市| 丹凤县| 厦门市| 光泽县| 城固县| 巴里| 社会| 衢州市| 吉林省| 德安县| 故城县| 平武县| 观塘区| 常山县| 毕节市| 太仆寺旗| 乌兰浩特市| 曲靖市| 广安市| 宁国市| 开平市| 五峰| 调兵山市| 洞头县| 汕头市| 黎平县| 思茅市| 南宫市| 临清市| 全椒县| 凉城县| 沧源| 榆社县| 嘉善县| 格尔木市| 五莲县| 崇明县| 化德县| 安岳县|