」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 避免在具有多個狀態的 React 中進行不必要的重新渲染

避免在具有多個狀態的 React 中進行不必要的重新渲染

發佈於2024-11-07
瀏覽:999

Evitando Re-renderizações Desnecessárias em React com Múltiplos Estados

使用狀態來控制介面的不同部分是很常見的。然而,如果管理不好,多個狀態可能會導致不必要的重新渲染,影響系統效能。

問題:太多狀態 === 太多重新渲染

假設我們有一個管理使用者資料的元件。我們可以獨立聲明這些狀態,如下所示:

const UserComponent = () => {
  const [name, setName] = useState('');
  const [age, setAge] = useState(0);
  const [address, setAddress] = useState('');
  const [email, setEmail] = useState('');
  const [phone, setPhone] = useState('');
  const [occupation, setOccupation] = useState('');

  // Funções de atualização dos estados
  const updateName = (newName) => setName(newName);
  const updateAge = (newAge) => setAge(newAge);
  // e assim por diante...

  return (
    ...
  );
};

這裡我們有6個獨立的狀態,每次更新其中一個狀態時,整個元件都會重新渲染,現在想像一下我們需要更新這6個狀態...是的,我們渲染該組件6 次。

解決方案:僅建立 1 個有關使用者資訊的狀態

緩解此問題的一種方法是將所有狀態合併到一個物件中。我們可以將所有用戶資訊保留在一種狀態中,而不是擁有單獨的狀態,它看起來像這樣:

const UserComponent = () => {
  const [user, setUser] = useState({
    name: '',
    age: 0,
    address: '',
    email: '',
    phone: '',
    occupation: ''
  });

  // Função para atualizar o estado do usuário
  const updateUser = (newData) => {
    setUser((prevState) => ({
      ...prevUser,
      ...newData,
    }));
  };

  return (
    ...
  );
};

現在,我們不再為每個狀態提供一個函數,而是使用 updateUser 函數,該函數僅接收所需的更改,並使用擴充運算子 (...) 將它們與先前的狀態組合起來。這允許您僅更新狀態的一部分,而其餘部分保持不變。

如果您只想更改有關對象的 1 個信息,請執行以下操作:

setUser((prevState) => ({...prevState, age: 25}))

不同之處

當我們使用單獨的狀態時,每個單獨的狀態變更都會導致元件的重新渲染。當我們將所有狀態合併到一個物件中時,我們仍然有一個重新渲染,但它只會發生一次,即使物件的多個部分發生變化。

優點

- 減少重新渲染: 透過合併狀態,我們避免了多次不必要的重新渲染,從而提高了效能。
- 更容易維護: 更容易在單一狀態下管理使用者訊息,簡化程式碼,更具可讀性。
- 部分控制更新: 我們只能更改狀態中需要修改的部分,而不能更改其餘部分。

還有那個!我希望我有幫助!
雖然我還在開發中,但這是我的作品集:https://lucaslima.vercel.app(我希望當你訪問它時,它已經準備好了哈哈哈)

成功! ?

版本聲明 本文轉載於:https://dev.to/lucaslimasz/evitando-re-renderizacoes-desnecessarias-em-react-com-multiplos-estados-nae?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3