<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
把“建立”函數和依賴項陣列作為引數傳⼊入useMemo,它僅會在某個依賴項改變時才重新計算memoized 值。這種優化有助於避免在每次渲染時都進⾏行行⾼高開銷的計算。
importReact, { useState, useMemo } from"react"; export default functionUseMemoPage(props) { const [count, setCount] =useState(0); constexpensive=useMemo(() => { console.log("compute"); let sum=0; for (leti=0; i<count; i++) { sum+=i; } return sum;//只有count變化,這⾥裡里才重新執⾏行行 }, [count]); const [value, setValue] =useState(""); return (<div><h3>UseMemoPage</h3> <p>expensive:{expensive}</p><p>{count}</p> <button onClick={() =>setCount(count+1)}>add</button> <input value={value} onChange={event=>setValue(event.target.value)} /></div> ); }
把內聯回撥函數及依賴項陣列作為引數傳⼊入useCallback,它將返回該回撥函數的 memoized 版本,該回撥函數僅在某個依賴項改變時才會更更新。當你把回撥函數傳遞給經過優化的並使⽤用引⽤用相等性去避免⾮非必要渲染(例例如shouldComponentUpdate)的⼦子元件時,它將⾮非常有⽤用
importReact, { useState, useCallback, PureComponent } from"react"; export default function UseCallbackPage(props) { const [count, setCount] =useState(0); const addClick=useCallback(() => { let sum=0; for (leti=0; i<count; i++) { sum+=i; } return sum; }, [count]); const [value, setValue] =useState(""); return ( <div><h3>UseCallbackPage</h3> <p>{count}</p> <buttononClick={() =>setCount(count+1)}>add</button> <inputvalue={value} onChange={event=>setValue(event.target.value)} /> <ChildaddClick={addClick} /></div> ); } class ChildextendsPureComponent { render() { console.log("child render"); const { addClick } =this.props; return ( <div><h3>Child</h3> <buttononClick={() =>console.log(addClick())}>add</button></div> ) } }
useCallback(fn, deps)相當於useMemo(() => fn, deps)。
注意依賴項陣列不不會作為引數傳給“建立”函數。雖然從概念上來說它表現為:所有“建立”函數中引⽤用的值都應該出現在依賴項陣列中。未來編譯器器會更更加智慧,屆時⾃自動建立陣列將成為可能。
補充介紹React的memo與useMemo及useCallback
props
相同的引數時,淺對比之後有之前的傳入項,則複用快取最近一次結果shouldComponetUpdate
返回值混合React.PureComponent
shouldComponentUpdate
useState
,會快取 state 值,不會拿到實時更新的值到此這篇關於React中useMemo與useCallback的區別的文章就介紹到這了,更多相關React useMemo與useCallback區別內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45