React.memo---性能優(yōu)化---使用小記

問題

父組件的state發(fā)生變化,就會(huì)重新 render其下的子組件、即使沒有用到的state,也會(huì)重新render,不符合要求,需要優(yōu)化;

解決

使用React.memo包裹子組件

const Children= memo(() => {
  return <>xxx</>;
});

memo使用淺比較,如想深比較,根據(jù)官網(wǎng)例子,傳入自定義函數(shù)

import { isEqual } from "lodash";
function MyComponent(props) {
  /* 使用 props 渲染 */
}
function areEqual(prevProps, nextProps) {
  /*
  如果把 nextProps 傳入 render 方法的返回結(jié)果與
  將 prevProps 傳入 render 方法的返回結(jié)果一致則返回 true,
  否則返回 false
  false 則為繼續(xù)渲染;
  true  則為阻止渲染
  */
return isEqual(prevProps,nextProps)
}
export default React.memo(MyComponent, areEqual);

實(shí)例:

加年齡不會(huì)重新渲染子組件,改名字會(huì)!

import { useState, memo, useEffect } from "react";
import { isEqual } from "lodash";

const Children = memo(
  ({ name }) => {
    console.log("我是子組件");
    return (
      <>
        <h1>{`hello ${name}!`}</h1>
      </>
    );
  },
  (prevProps, nextProps) => {
    return isEqual(prevProps, nextProps);
  }
);

export default function Home() {
  const [name, setName] = useState("小王");
  const [age, setAge] = useState(25);

  return (
    <div>
      <button onClick={() => setAge(age + 1)}>點(diǎn)我加一歲</button>
      <br />
      <button
        onClick={() => {
          setName("小王" + (Math.random(1) * 100).toFixed(2));
        }}
      >
        換名字
      </button>
      <Children name={name} />
      年齡 :{age}
    </div>
  );
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容