{"id":68864,"date":"2026-01-30T20:41:09","date_gmt":"2026-01-30T12:41:09","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/68864.html"},"modified":"2026-01-30T20:41:09","modified_gmt":"2026-01-30T12:41:09","slug":"usememo%e7%9a%84%e7%90%86%e8%a7%a3%e4%b8%8e%e5%ba%94%e7%94%a8","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/68864.html","title":{"rendered":"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528"},"content":{"rendered":"<p>useMemo \u4f60\u5c31\u628a\u5b83\u5f53\u6210&#xff1a;\u201c\u7f13\u5b58\u4e00\u4e2a\u8ba1\u7b97\u7ed3\u679c\/\u7f13\u5b58\u4e00\u4e2a\u5f15\u7528\u201d&#xff0c;\u53ea\u6709\u4f9d\u8d56\u53d8\u4e86\u624d\u91cd\u65b0\u7b97\u3002\u5b83\u89e3\u51b3\u4e24\u7c7b\u6700\u5e38\u89c1\u95ee\u9898&#xff1a;\u6027\u80fd \u548c \u5f15\u7528\u53d8\u5316\u5bfc\u81f4\u7684\u91cd\u590d\u89e6\u53d1\u3002<\/p>\n<\/p>\n<h3>1) useMemo \u5230\u5e95\u505a\u4e86\u4ec0\u4e48&#xff1f;<\/h3>\n<p>const value &#061; useMemo(() &#061;&gt; computeExpensive(x), [x])<\/p>\n<ul>\n<li>\n<p>React \u5148\u7b97\u4e00\u6b21 computeExpensive(x)&#xff0c;\u628a\u7ed3\u679c \u8bb0\u4f4f<\/p>\n<\/li>\n<li>\n<p>\u4e4b\u540e\u7ec4\u4ef6\u6bcf\u6b21\u91cd\u65b0\u6e32\u67d3&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u5982\u679c x \u6ca1\u53d8&#xff1a;\u76f4\u63a5\u7528\u65e7\u7ed3\u679c&#xff0c;\u4e0d\u91cd\u65b0\u7b97<\/p>\n<\/li>\n<li>\n<p>\u5982\u679c x \u53d8\u4e86&#xff1a;\u91cd\u65b0\u7b97\u4e00\u6b21\u5e76\u66f4\u65b0\u7f13\u5b58<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p>\u4e00\u53e5\u8bdd&#xff1a;\u4f9d\u8d56\u4e0d\u53d8 \u2192 \u590d\u7528\u65e7\u7ed3\u679c&#xff1b;\u4f9d\u8d56\u53d8\u5316 \u2192 \u91cd\u65b0\u8ba1\u7b97\u3002<\/p>\n<\/p>\n<h3>2) \u7528\u9014 A&#xff1a;\u4f18\u5316\u201c\u5f88\u6162\u7684\u8ba1\u7b97\u201d<\/h3>\n<\/p>\n<p>const doubled &#061; useMemo(() &#061;&gt; slowDouble(number), [number])<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u6539 number \u2192 \u9700\u8981\u91cd\u65b0\u7b97&#xff08;\u5408\u7406&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u5207\u6362\u4e3b\u9898 dark \u2192 \u4e0d\u7528\u91cd\u65b0\u7b97&#xff08;\u7701\u6389\u5361\u987f&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>\u2705 \u4ec0\u4e48\u65f6\u5019\u503c\u5f97\u7528&#xff1f;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u8ba1\u7b97\u771f\u7684\u6162&#xff08;\u5927\u5faa\u73af\u3001\u590d\u6742\u8fc7\u6ee4\u6392\u5e8f\u3001\u56fe\u8868\u6570\u636e\u5904\u7406\u3001\u52a0\u5bc6\/\u54c8\u5e0c\u3001\u590d\u6742\u683c\u5f0f\u5316&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6216\u8005\u8ba1\u7b97\u91cf\u968f\u6570\u636e\u89c4\u6a21\u53d8\u5927\u5f88\u660e\u663e&#xff08;\u6bd4\u5982 1w \u6761\u5217\u8868\u7684 filter &#043; sort&#xff09;<\/p>\n<\/li>\n<\/ul>\n<h3>3) \u7528\u9014 B&#xff1a;\u89e3\u51b3\u201c\u5f15\u7528\u6bcf\u6b21\u53d8\u5bfc\u81f4 useEffect \u4e71\u89e6\u53d1\u201d<\/h3>\n<\/p>\n<p>JS \u91cc\u5bf9\u8c61\/\u6570\u7ec4\u6bd4\u8f83\u7684\u662f \u5f15\u7528\u5730\u5740&#xff0c;\u4e0d\u662f\u5185\u5bb9\u3002<\/p>\n<\/p>\n<h4>\u95ee\u9898\u4f8b\u5b50<\/h4>\n<p>const themeStyle &#061; { color: dark ? &#034;white&#034; : &#034;black&#034; }<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  console.log(&#034;theme changed&#034;)<br \/>\n}, [themeStyle])<\/p>\n<p>\u6bcf\u6b21\u6e32\u67d3\u90fd\u4f1a\u521b\u5efa\u4e00\u4e2a\u65b0\u5bf9\u8c61 {&#8230;}&#xff0c;\u5f15\u7528\u6c38\u8fdc\u4e0d\u4e00\u6837 \u2192 effect \u6bcf\u6b21\u90fd\u89e6\u53d1\u3002<\/p>\n<\/p>\n<h4>\u7528 useMemo \u4fee<\/h4>\n<p>const themeStyle &#061; useMemo(<br \/>\n  () &#061;&gt; ({ color: dark ? &#034;white&#034; : &#034;black&#034; }),<br \/>\n  [dark]<br \/>\n)<\/p>\n<p>\u8fd9\u6837\u53ea\u6709 dark \u53d8&#xff0c;themeStyle \u7684\u5f15\u7528\u624d\u53d8&#xff0c;effect \u624d\u4f1a\u89e6\u53d1\u3002<\/p>\n<\/p>\n<p>\u4f60\u6ca1\u7406\u89e3\u7684\u70b9\u5176\u5b9e\u5c31\u4e00\u4e2a&#xff1a;useEffect \u7684\u4f9d\u8d56\u6bd4\u8f83\u65b9\u5f0f\u3002<\/p>\n<\/p>\n<p>React \u5224\u65ad\u4f9d\u8d56\u53d8\u6ca1\u53d8&#xff0c;\u4e0d\u662f\u770b\u201c\u5185\u5bb9\u4e00\u6837\u4e0d\u4e00\u6837\u201d&#xff0c;\u800c\u662f\u770b\u662f\u4e0d\u662f\u540c\u4e00\u4e2a\u5f15\u7528&#xff08;\u5185\u5b58\u5730\u5740&#xff09;\u3002<\/p>\n<\/p>\n<h3>4) \u6ca1\u6709 useMemo&#xff1a;\u4e3a\u4ec0\u4e48\u4f1a\u201c\u4e71\u89e6\u53d1\u201d&#xff1f;<\/h3>\n<p>const config &#061; { chainId, address }<br \/>\nuseEffect(() &#061;&gt; {<br \/>\n  console.log(&#034;run&#034;)<br \/>\n}, [config])<\/p>\n<p>\u5173\u952e&#xff1a;{ chainId, address } \u8fd9\u4e00\u884c \u6bcf\u6b21\u6e32\u67d3\u90fd\u4f1a\u521b\u5efa\u4e00\u4e2a\u5168\u65b0\u7684\u5bf9\u8c61\u3002<\/p>\n<\/p>\n<p>\u5373\u4f7f chainId \u548c address \u90fd\u6ca1\u53d8&#xff0c;config \u4e5f\u662f\u201c\u65b0\u5bf9\u8c61\u201d\u3002<\/p>\n<\/p>\n<p>\u4f60\u53ef\u4ee5\u60f3\u8c61\u6210\u8fd9\u6837&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u7b2c1\u6b21\u6e32\u67d3&#xff1a;config \u6307\u5411 0xAAA<\/p>\n<\/li>\n<li>\n<p>\u7b2c2\u6b21\u6e32\u67d3&#xff1a;\u53c8 new \u4e86\u4e00\u4e2a\u5bf9\u8c61&#xff0c;config \u6307\u5411 0xBBB<\/p>\n<\/li>\n<li>\n<p>\u7b2c3\u6b21\u6e32\u67d3&#xff1a;\u53c8 new \u4e86\u4e00\u4e2a\u5bf9\u8c61&#xff0c;config \u6307\u5411 0xCCC<\/p>\n<\/li>\n<\/ul>\n<p>React \u770b\u4f9d\u8d56 [config]&#xff1a;<\/p>\n<p>\u201c\u54a6&#xff0c;\u5f15\u7528\u4ece 0xAAA \u53d8\u6210 0xBBB \u4e86 \u2192 \u4f9d\u8d56\u53d8\u4e86 \u2192 effect \u6267\u884c\u3002\u201d<\/p>\n<\/p>\n<p>\u6240\u4ee5\u4f60\u4f1a\u770b\u5230&#xff1a;\u53ea\u8981\u7ec4\u4ef6\u91cd\u65b0\u6e32\u67d3\u4e00\u6b21&#xff08;\u54ea\u6015\u56e0\u4e3a theme\u3001\u8f93\u5165\u6846\u3001\u522b\u7684 state&#xff09;&#xff0c;effect \u5c31\u4f1a\u8dd1\u4e00\u6b21\u3002<\/p>\n<\/p>\n<h3>5) \u6709 useMemo&#xff1a;\u4e3a\u4ec0\u4e48\u5c31\u4e0d\u4e71\u89e6\u53d1&#xff1f;<\/h3>\n<p>const config &#061; useMemo(() &#061;&gt; ({ chainId, address }), [chainId, address])<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  console.log(&#034;run only when chainId\/address changes&#034;)<br \/>\n}, [config])<\/p>\n<p>useMemo \u505a\u7684\u4e8b&#xff1a;\u7f13\u5b58\u4e0a\u4e00\u6b21\u521b\u5efa\u7684\u5bf9\u8c61\u3002<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u5982\u679c chainId\/address \u6ca1\u53d8&#xff1a;useMemo \u76f4\u63a5\u628a\u4e0a\u4e00\u6b21\u90a3\u4e2a\u5bf9\u8c61\u8fd4\u56de\u7ed9\u4f60&#xff08;\u5f15\u7528\u4e0d\u53d8&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u5982\u679c chainId\/address \u53d8\u4e86&#xff1a;useMemo \u624d\u4f1a\u521b\u5efa\u65b0\u5bf9\u8c61&#xff08;\u5f15\u7528\u6539\u53d8&#xff09;<\/p>\n<\/li>\n<\/ul>\n<p>\u6240\u4ee5\u53d8\u6210&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u7b2c1\u6b21\u6e32\u67d3&#xff1a;config \u6307\u5411 0xAAA<\/p>\n<\/li>\n<li>\n<p>\u7b2c2\u6b21\u6e32\u67d3&#xff08;theme \u53d8\u4e86&#xff0c;\u4f46 chainId\/address \u6ca1\u53d8&#xff09;&#xff1a;useMemo \u8fd4\u56de\u65e7\u7684 0xAAA<\/p>\n<\/li>\n<li>\n<p>\u7b2c3\u6b21\u6e32\u67d3&#xff08;\u522b\u7684 state \u53d8\u4e86&#xff09;&#xff1a;\u8fd8\u662f 0xAAA<\/p>\n<\/li>\n<li>\n<p>\u76f4\u5230\u67d0\u6b21 chainId\/address \u53d8\u4e86&#xff1a;\u624d\u751f\u6210 0xBBB<\/p>\n<\/li>\n<\/ul>\n<p>React \u770b\u4f9d\u8d56 [config]&#xff1a;<\/p>\n<p>\u201c\u5f15\u7528\u6ca1\u53d8 \u2192 \u4f9d\u8d56\u6ca1\u53d8 \u2192 effect \u4e0d\u6267\u884c\u3002\u201d<\/p>\n<\/p>\n<h3>6) \u7528\u4e00\u53e5\u8d85\u7ea7\u76f4\u89c2\u7684\u8bdd\u603b\u7ed3\u5dee\u522b<\/h3>\n<\/p>\n<ul>\n<li>\n<p>\u6ca1\u6709 useMemo&#xff1a;\u6bcf\u6b21\u6e32\u67d3\u90fd\u201cnew \u4e00\u4e2a config\u201d \u2192 useEffect \u89c9\u5f97\u4f9d\u8d56\u53d8\u4e86 \u2192 \u6bcf\u6b21\u90fd\u8dd1<\/p>\n<\/li>\n<li>\n<p>\u6709 useMemo&#xff1a;\u53ea\u6709\u5f53 chainId\/address \u53d8\u65f6\u624d\u201cnew config\u201d \u2192 useEffect \u53ea\u5728\u771f\u6b63\u53d8\u5316\u65f6\u8dd1<\/p>\n<\/li>\n<\/ul>\n<h3>7) \u4f60\u53ef\u80fd\u4f1a\u95ee&#xff1a;\u90a3\u6211\u4e3a\u4ec0\u4e48\u4e0d\u76f4\u63a5\u5199\u00a0 [chainId, address] &#xff1f;<\/h3>\n<\/p>\n<p>\u5bf9&#xff0c;\u8fd9\u4e2a\u95ee\u9898\u95ee\u5f97\u5f88\u5bf9\u3002<\/p>\n<\/p>\n<p>\u5f88\u591a\u65f6\u5019\u6700\u7b80\u5355\u5c31\u662f\u8fd9\u6837&#xff1a;<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  console.log(&#034;run only when chainId\/address changes&#034;)<br \/>\n}, [chainId, address])<\/p>\n<p>\u90a3\u4e3a\u4ec0\u4e48\u8fd8\u8981 config &#043; useMemo&#xff1f;<\/p>\n<p>\u5e38\u89c1\u539f\u56e0&#xff1a;<\/p>\n<\/p>\n<li>\n<p>\u4f60\u4e0b\u6e38\u9700\u8981\u4e00\u4e2a config \u5bf9\u8c61\u4f20\u7ed9\u522b\u7684 hook \/ \u5b50\u7ec4\u4ef6&#xff08;\u6bd4\u5982 wagmi\/viem&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4f9d\u8d56\u9879\u5f88\u591a&#xff0c;\u4f60\u60f3\u7edf\u4e00\u6253\u5305\u6210\u4e00\u4e2a\u5bf9\u8c61&#xff08;\u65b9\u4fbf\u7ef4\u62a4&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u5b50\u7ec4\u4ef6\u662f React.memo&#xff0c;\u4f60\u9700\u8981\u4fdd\u8bc1 props \u5f15\u7528\u7a33\u5b9a<\/p>\n<\/li>\n<h3>8) \u4e00\u4e2a\u6700\u80fd\u8ba9\u4f60\u201c\u79d2\u61c2\u201d\u7684\u7c7b\u6bd4<\/h3>\n<\/p>\n<ul>\n<li>\n<p>\u6ca1\u6709 useMemo&#xff1a;\u4f60\u6bcf\u6b21\u6e32\u67d3\u90fd\u201c\u91cd\u65b0\u6253\u5370\u4e00\u5f20\u8eab\u4efd\u8bc1\u201d&#xff0c;\u8eab\u4efd\u8bc1\u53f7\u7801\u5f53\u7136\u53d8 \u2192 \u7cfb\u7edf\u8ba4\u4e3a\u6362\u4eba\u4e86 \u2192 effect \u89e6\u53d1<\/p>\n<\/li>\n<li>\n<p>\u6709 useMemo&#xff1a;\u53ea\u8981\u4fe1\u606f\u6ca1\u53d8&#xff0c;\u4f60\u5c31\u4e00\u76f4\u7528\u540c\u4e00\u5f20\u8eab\u4efd\u8bc1 \u2192 \u7cfb\u7edf\u8ba4\u4e3a\u8fd8\u662f\u540c\u4e00\u4e2a\u4eba \u2192 effect \u4e0d\u89e6\u53d1<\/p>\n<\/li>\n<\/ul>\n<\/p>\n<h3>9) useMemo vs useCallback&#xff1a;\u522b\u6df7<\/h3>\n<\/p>\n<ul>\n<li>\n<p>useMemo&#xff1a;\u7f13\u5b58\u201c\u503c\u201d<\/p>\n<\/li>\n<li>\n<p>useCallback&#xff1a;\u7f13\u5b58\u201c\u51fd\u6570\u201d<\/p>\n<p>\u5176\u5b9e\u4f60\u53ef\u4ee5\u7406\u89e3\u4e3a&#xff1a;<\/p>\n<\/li>\n<\/ul>\n<p>useCallback(fn, deps) &#061;&#061;&#061; useMemo(() &#061;&gt; fn, deps)<\/p>\n<p>\u4e00\u4e2a\u7f13\u5b58\u7ed3\u679c&#xff0c;\u4e00\u4e2a\u7f13\u5b58\u51fd\u6570\u5f15\u7528\u3002<\/p>\n<\/p>\n<h3>10) \u5b9e\u6218<\/h3>\n<\/p>\n<p>\u4e0b\u9762\u4ecb\u7ecd\u00a06 \u4e2a\u771f\u5b9e\u9879\u76ee\u91cc\u6700\u5e38\u89c1\u3001\u800c\u4e14\u201c\u7528\u4e0d\u7528 useMemo \u5dee\u522b\u975e\u5e38\u660e\u663e\u201d\u7684\u4f8b\u5b50&#xff08;\u6bcf\u4e2a\u90fd\u8bf4\u660e&#xff1a;\u4e0d\u7528\u4f1a\u600e\u6837&#xff0c;\u7528\u4e86\u4f1a\u600e\u6837&#xff09;\u3002<\/p>\n<\/p>\n<h3>\u4f8b\u5b50 1&#xff1a;\u5bf9\u8c61\u4f5c\u4e3a useEffect \u4f9d\u8d56\u5bfc\u81f4\u91cd\u590d\u8bf7\u6c42&#xff08;\u62c9\u4f59\u989d\/\u4ea4\u6613&#xff09;<\/h3>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;\u4f1a\u91cd\u590d\u8bf7\u6c42&#xff09;<\/p>\n<p>const params &#061; { address, chainId }<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  fetchBalance(params) \/\/ \u53ef\u80fd\u6bcf\u6b21\u6e32\u67d3\u90fd\u8bf7\u6c42<br \/>\n}, [params])<\/p>\n<p>\u53ea\u8981\u7ec4\u4ef6\u56e0\u4e3a\u522b\u7684 state \u6539\u4e86&#xff08;\u4e3b\u9898\u3001\u8f93\u5165\u6846\u3001\u5f39\u7a97&#xff09;&#xff0c;params \u5c31\u662f\u65b0\u5bf9\u8c61 \u2192 effect \u53c8\u8dd1 \u2192 \u53c8\u8bf7\u6c42\u3002<\/p>\n<\/p>\n<p>\u7528 useMemo&#xff08;\u53ea\u5728 address\/chainId \u53d8\u65f6\u8bf7\u6c42&#xff09;<\/p>\n<p>const params &#061; useMemo(() &#061;&gt; ({ address, chainId }), [address, chainId])<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  fetchBalance(params)<br \/>\n}, [params])<\/p>\n<h3>\u4f8b\u5b50 2&#xff1a;\u7ed9 wagmi\/viem \u4f20 config&#xff0c;\u5bf9\u8c61\u4e0d\u7a33\u5b9a\u5bfc\u81f4 hook \u91cd\u590d\u6267\u884c\/\u91cd\u590d\u8ba2\u9605<\/h3>\n<\/p>\n<p>\u5f88\u591a Web3 hook \u5185\u90e8\u4f1a\u770b config \u662f\u5426\u53d8\u5316\u6765\u91cd\u5efa watcher\u3002<\/p>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;\u53ef\u80fd\u53cd\u590d\u91cd\u5efa watcher \/ \u91cd\u8dd1&#xff09;<\/p>\n<p>const config &#061; { address, abi, functionName: &#034;balanceOf&#034;, args: [user] }<br \/>\nuseReadContract(config)<\/p>\n<p>\u7528 useMemo&#xff08;config \u7a33\u5b9a&#xff0c;\u53ea\u6709\u5173\u952e\u53c2\u6570\u53d8\u624d\u91cd\u5efa&#xff09;<\/p>\n<p>const config &#061; useMemo(() &#061;&gt; ({<br \/>\n  address,<br \/>\n  abi,<br \/>\n  functionName: &#034;balanceOf&#034;,<br \/>\n  args: [user],<br \/>\n}), [address, abi, user])<\/p>\n<p>useReadContract(config)<\/p>\n<hr \/>\n<h3>\u4f8b\u5b50 3&#xff1a;\u5217\u8868\u8fc7\u6ee4\/\u6392\u5e8f\u5f88\u5927&#xff0c;\u5bfc\u81f4 UI \u5361&#xff08;\u4ea4\u6613\u5217\u8868\u3001NFT \u5217\u8868&#xff09;<\/h3>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;\u4efb\u4f55\u72b6\u6001\u53d8\u5316\u90fd\u91cd\u65b0 filter\/sort&#xff09;<\/p>\n<p>const visibleTxs &#061; txs<br \/>\n  .filter(tx &#061;&gt; tx.chainId &#061;&#061;&#061; chainId)<br \/>\n  .sort((a,b) &#061;&gt; b.time &#8211; a.time)<\/p>\n<p>\u4f60\u4e00\u5207\u6362 theme\u3001\u6253\u5f00\u5f39\u7a97\u3001\u8f93\u5165\u641c\u7d22\u6846&#xff0c;\u90fd\u4f1a\u91cd\u65b0\u8dd1\u8fd9\u5957\u903b\u8f91 \u2192 \u5361\u3002<\/p>\n<\/p>\n<p>\u7528 useMemo&#xff08;\u53ea\u5728 txs \u6216 chainId \u53d8\u65f6\u91cd\u7b97&#xff09;<\/p>\n<p>const visibleTxs &#061; useMemo(() &#061;&gt; {<br \/>\n  return txs<br \/>\n    .filter(tx &#061;&gt; tx.chainId &#061;&#061;&#061; chainId)<br \/>\n    .sort((a,b) &#061;&gt; b.time &#8211; a.time)<br \/>\n}, [txs, chainId])<\/p>\n<hr \/>\n<h3>\u4f8b\u5b50 4&#xff1a;\u628a derived data&#xff08;\u6d3e\u751f\u6570\u636e&#xff09;\u4f20\u7ed9 React.memo \u5b50\u7ec4\u4ef6&#xff0c;\u907f\u514d\u5b50\u7ec4\u4ef6\u65e0\u610f\u4e49\u91cd\u6e32<\/h3>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;\u5b50\u7ec4\u4ef6\u6bcf\u6b21\u90fd\u6e32\u67d3&#xff09;<\/p>\n<p>const columns &#061; [<br \/>\n  { key: &#034;hash&#034;, title: &#034;Hash&#034; },<br \/>\n  { key: &#034;status&#034;, title: &#034;Status&#034; },<br \/>\n]<\/p>\n<p>return &lt;Table columns&#061;{columns} \/&gt; \/\/ Table \u5373\u4f7f memo&#xff0c;\u4e5f\u4f1a\u56e0\u4e3a columns \u5f15\u7528\u53d8\u800c\u91cd\u6e32<\/p>\n<p>\u7528 useMemo&#xff08;columns \u5f15\u7528\u7a33\u5b9a&#xff0c;Table \u4e0d\u4f1a\u4e71\u6e32&#xff09;<\/p>\n<p>const columns &#061; useMemo(() &#061;&gt; ([<br \/>\n  { key: &#034;hash&#034;, title: &#034;Hash&#034; },<br \/>\n  { key: &#034;status&#034;, title: &#034;Status&#034; },<br \/>\n]), [])<\/p>\n<p>return &lt;Table columns&#061;{columns} \/&gt;<\/p>\n<hr \/>\n<h3>\u4f8b\u5b50 5&#xff1a;useEffect \u4f9d\u8d56\u4e00\u4e2a options \u5bf9\u8c61&#xff08;\u6bd4\u5982\u56fe\u8868\/\u7f16\u8f91\u5668\/SDK \u521d\u59cb\u5316&#xff09;&#xff0c;\u5bfc\u81f4\u91cd\u590d\u521d\u59cb\u5316<\/h3>\n<\/p>\n<p>\u6bd4\u5982\u521d\u59cb\u5316\u4e00\u4e2a chart\/\u64ad\u653e\u5668\/websocket SDK\u3002<\/p>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;effect \u6bcf\u6b21 render \u90fd cleanup &#043; init&#xff09;<\/p>\n<p>const options &#061; { theme: dark ? &#034;dark&#034; : &#034;light&#034;, locale }<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  const chart &#061; createChart(options)<br \/>\n  return () &#061;&gt; chart.destroy()<br \/>\n}, [options])<\/p>\n<p>\u7528 useMemo&#xff08;\u53ea\u5728 theme\/locale \u771f\u53d8\u65f6\u91cd\u5efa&#xff09;<\/p>\n<p>const options &#061; useMemo(() &#061;&gt; ({<br \/>\n  theme: dark ? &#034;dark&#034; : &#034;light&#034;,<br \/>\n  locale,<br \/>\n}), [dark, locale])<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  const chart &#061; createChart(options)<br \/>\n  return () &#061;&gt; chart.destroy()<br \/>\n}, [options])<\/p>\n<hr \/>\n<h3>\u4f8b\u5b50 6&#xff1a;\u4f9d\u8d56\u6570\u7ec4&#xff08;args&#xff09;\u4e0d\u7a33\u5b9a\u5bfc\u81f4 effect\/hook \u9891\u7e41\u89e6\u53d1<\/h3>\n<\/p>\n<p>\u4e0d\u7528 useMemo&#xff08;args \u6bcf\u6b21 render \u90fd\u662f\u65b0\u6570\u7ec4&#xff09;<\/p>\n<p>const args &#061; [spender, amount]<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  prepareTx(args)<br \/>\n}, [args])<\/p>\n<p>\u7528 useMemo&#xff08;args \u7a33\u5b9a&#xff09;<\/p>\n<p>const args &#061; useMemo(() &#061;&gt; [spender, amount], [spender, amount])<\/p>\n<p>useEffect(() &#061;&gt; {<br \/>\n  prepareTx(args)<br \/>\n}, [args])<\/p>\n<\/p>\n<h2>\u4f60\u8be5\u600e\u4e48\u5224\u65ad\u201c\u5230\u5e95\u8981\u4e0d\u8981\u7528 useMemo\u201d<\/h2>\n<\/p>\n<p>\u2705 \u7528\u5728\u8fd9\u4e24\u7c7b\u4e0a\u6700\u503c&#xff1a;<\/p>\n<\/p>\n<li>\n<p>\u4f60\u628a\u5bf9\u8c61\/\u6570\u7ec4\/\u51fd\u6570\u653e\u8fdb\u4f9d\u8d56\u6570\u7ec4&#xff08;useEffect\/useMemo\/useCallback deps&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4f60\u505a\u4e86\u91cd\u8ba1\u7b97&#xff08;filter\/sort\/map \u5927\u6570\u636e\/\u590d\u6742\u8f6c\u6362&#xff09;<\/p>\n<\/li>\n<p>\u274c \u522b\u7528\u5728&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u7b80\u5355\u8ba1\u7b97&#xff08;a&#043;b\u3001\u62fc\u5b57\u7b26\u4e32&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u6ca1\u6709\u4f9d\u8d56\u95ee\u9898\u4e5f\u6ca1\u6709\u5361\u987f\u95ee\u9898\u7684\u5730\u65b9<\/p>\n<\/li>\n<li>\n<\/li>\n<\/ul>\n<h3>11) \u4ec0\u4e48\u65f6\u5019\u522b\u7528&#xff1f;<\/h3>\n<\/p>\n<p>useMemo \u4e0d\u662f\u201c\u8d8a\u591a\u8d8a\u597d\u201d&#xff0c;\u5b83\u672c\u8eab\u4e5f\u6709\u5f00\u9500&#xff08;\u8981\u7ef4\u62a4\u7f13\u5b58\u3001\u6bd4\u8f83 deps&#xff09;\u3002<\/p>\n<p>\u522b\u7528\u5728&#xff1a;<\/p>\n<\/p>\n<ul>\n<li>\n<p>\u8ba1\u7b97\u5f88\u8f7b&#xff08;a&#043;b\u3001\u7b80\u5355 map&#xff09;<\/p>\n<\/li>\n<li>\n<p>\u4f60\u6839\u672c\u6ca1\u9047\u5230\u6027\u80fd\u95ee\u9898\/\u91cd\u590d\u89e6\u53d1\u95ee\u9898<\/p>\n<\/li>\n<li>\n<p>deps \u5199\u4e0d\u5bf9\u53cd\u800c\u66f4\u96be debug<\/p>\n<\/li>\n<\/ul>\n<\/p>\n<h3>12) \u603b\u7ed3<\/h3>\n<\/p>\n<p>useMemo &#061; \u7f13\u5b58\u4e00\u4e2a\u503c&#xff08;\u5c24\u5176\u662f\u6162\u8ba1\u7b97\u7ed3\u679c \u6216 \u9700\u8981\u7a33\u5b9a\u5f15\u7528\u7684\u5bf9\u8c61\/\u6570\u7ec4&#xff09;&#xff0c;\u4f9d\u8d56\u4e0d\u53d8\u5c31\u590d\u7528\u3002<\/p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>useMemo \u4f60\u5c31\u628a\u5b83\u5f53\u6210&#xff1a;\u201c\u7f13\u5b58\u4e00\u4e2a\u8ba1\u7b97\u7ed3\u679c\/\u7f13\u5b58\u4e00\u4e2a\u5f15\u7528\u201d&#xff0c;\u53ea\u6709\u4f9d\u8d56\u53d8\u4e86\u624d\u91cd\u65b0\u7b97\u3002\u5b83\u89e3\u51b3\u4e24\u7c7b\u6700\u5e38\u89c1\u95ee\u9898&#xff1a;\u6027\u80fd \u548c \u5f15\u7528\u53d8\u5316\u5bfc\u81f4\u7684\u91cd\u590d\u89e6\u53d1\u30021) useMemo \u5230\u5e95\u505a\u4e86\u4ec0\u4e48&#xff1f;const value  useMemo(() &gt; computeExpensive(x), [x])React \u5148\u7b97\u4e00\u6b21 computeExpensive(x)&#xff0c;\u628a\u7ed3\u679c \u8bb0\u4f4f\u4e4b\u540e\u7ec4\u4ef6\u6bcf\u6b21\u91cd\u65b0\u6e32\u67d3&#xff1a;\u5982\u679c x \u6ca1\u53d8&amp;#<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[187,724,87,885,190],"topic":[],"class_list":["post-68864","post","type-post","status-publish","format-standard","hentry","category-server","tag-javascript","tag-reactjs","tag-87","tag-885","tag-190"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/68864.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"useMemo \u4f60\u5c31\u628a\u5b83\u5f53\u6210&#xff1a;\u201c\u7f13\u5b58\u4e00\u4e2a\u8ba1\u7b97\u7ed3\u679c\/\u7f13\u5b58\u4e00\u4e2a\u5f15\u7528\u201d&#xff0c;\u53ea\u6709\u4f9d\u8d56\u53d8\u4e86\u624d\u91cd\u65b0\u7b97\u3002\u5b83\u89e3\u51b3\u4e24\u7c7b\u6700\u5e38\u89c1\u95ee\u9898&#xff1a;\u6027\u80fd \u548c \u5f15\u7528\u53d8\u5316\u5bfc\u81f4\u7684\u91cd\u590d\u89e6\u53d1\u30021) useMemo \u5230\u5e95\u505a\u4e86\u4ec0\u4e48&#xff1f;const value useMemo(() &gt; computeExpensive(x), [x])React \u5148\u7b97\u4e00\u6b21 computeExpensive(x)&#xff0c;\u628a\u7ed3\u679c \u8bb0\u4f4f\u4e4b\u540e\u7ec4\u4ef6\u6bcf\u6b21\u91cd\u65b0\u6e32\u67d3&#xff1a;\u5982\u679c x \u6ca1\u53d8&amp;#\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/68864.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-01-30T12:41:09+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/68864.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/68864.html\",\"name\":\"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-01-30T12:41:09+00:00\",\"dateModified\":\"2026-01-30T12:41:09+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/68864.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/68864.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/68864.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/68864.html","og_locale":"zh_CN","og_type":"article","og_title":"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"useMemo \u4f60\u5c31\u628a\u5b83\u5f53\u6210&#xff1a;\u201c\u7f13\u5b58\u4e00\u4e2a\u8ba1\u7b97\u7ed3\u679c\/\u7f13\u5b58\u4e00\u4e2a\u5f15\u7528\u201d&#xff0c;\u53ea\u6709\u4f9d\u8d56\u53d8\u4e86\u624d\u91cd\u65b0\u7b97\u3002\u5b83\u89e3\u51b3\u4e24\u7c7b\u6700\u5e38\u89c1\u95ee\u9898&#xff1a;\u6027\u80fd \u548c \u5f15\u7528\u53d8\u5316\u5bfc\u81f4\u7684\u91cd\u590d\u89e6\u53d1\u30021) useMemo \u5230\u5e95\u505a\u4e86\u4ec0\u4e48&#xff1f;const value useMemo(() &gt; computeExpensive(x), [x])React \u5148\u7b97\u4e00\u6b21 computeExpensive(x)&#xff0c;\u628a\u7ed3\u679c \u8bb0\u4f4f\u4e4b\u540e\u7ec4\u4ef6\u6bcf\u6b21\u91cd\u65b0\u6e32\u67d3&#xff1a;\u5982\u679c x \u6ca1\u53d8&amp;#","og_url":"https:\/\/www.wsisp.com\/helps\/68864.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-01-30T12:41:09+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"4 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/68864.html","url":"https:\/\/www.wsisp.com\/helps\/68864.html","name":"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-01-30T12:41:09+00:00","dateModified":"2026-01-30T12:41:09+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/68864.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/68864.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/68864.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"useMemo\u7684\u7406\u89e3\u4e0e\u5e94\u7528"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/68864","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=68864"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/68864\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=68864"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=68864"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=68864"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=68864"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}