当前位置: 首页 > news >正文

黄陂区政府网站 区建设局域名网站查询

黄陂区政府网站 区建设局,域名网站查询,怎么去投诉做网站的公司,专业的手机网站开发React.memo和usememo React.memo React.memo是一个高阶组件,对组件进行性能优化,主要用于优化函数组件的性能,如果一个组件在相同的props下渲染出相同的结果,但是又不需要在组件更新的时候重新渲染,就可以使用react.…

React.memo和usememo

React.memo

React.memo是一个高阶组件,对组件进行性能优化,主要用于优化函数组件的性能,如果一个组件在相同的props下渲染出相同的结果,但是又不需要在组件更新的时候重新渲染,就可以使用react.memo来对其进行性能优化
React.memo能够记忆组件的渲染,让它在prop没有发生变化的时候重用上一次的结果,从而避免不必要的渲染专门用于函数组件

const MyComponent = React.memo(function MyComponent(props) {//
}
const MyComponent = React.memo(props => {// 
})

在默认情况下,react.memo只会对props进行浅层比较,如果props的结果比较复杂或者包含了不可变的数据结构,需要传入第二个参数,一个比较函数,来定制更新时机。

const Mycomponent = React.memo(function MyComponent(props) {//},(prev, next) => {//}
)

React.memo仅检查props变化,如果函数组件中有使用useState,useReducer或者是useContext这些hook的时候,就算props没有发生变化,组件还是会重新渲染,内部组件状态的变化或者是上下文的变化都会导致组件的更新。
只有组件更新比较频繁,而且更新不依赖于内部状态或者上下文的时候,使用React.memo比较合适

  • React.memo可能会增加应用的内存使用量,因为需要记忆组件的渲染结果
  • 如果组件经常有新的props传入导致经常重新渲染,使用react.memo会导致性能的负担
  • 组件渲染很快,或者是更新不频繁,没有必要使用react.memo
  • 最好是在遇到性能瓶颈的时候使用这些优化手段

useMemo

useMemo接受两个参数,分别是一个函数和一个数组,实际上是以来,函数里return函数,数组内存放依赖

interface ChildProps {name: { name: string; color: string };onClick: Function;
}
const Child = ({ name, onClick}: ChildProps): JSX.Element => {console.log('子组件?')return(<><div style={{ color: name.color }}>我是一个子组件,父级传过来的数据:{name.name}</div><button onClick={onClick.bind(null, '新的子组件name')}>改变name</button></>);
}
const ChildMemo = memo(Child);const Page = (props) => {const [count, setCount] = useState(0);const [name, setName] = useState('Child组件');return (<><button onClick={(e) => { setCount(count+1) }}>1</button><p>count:{count}</p><ChildMemo //使用useMemo,返回一个和原本一样的对象,第二个参数是依赖性,当name发生改变的时候,才产生一个新的对象name={useMemo(()=>({ name, color: name.indexOf('name') !== -1 ? 'red' : 'green'}), [name])} onClick={ useCallback((newName: string) => setName(newName), []) }{/* useCallback((newName: string) => setName(newName),[]) */}{/* 这里使用了useCallback优化了传递给子组件的函数,只初始化一次这个函数,下次不产生新的函数/></>)
}
http://www.ds6.com.cn/news/63446.html

相关文章:

  • css网页设计代码模板日照网站优化公司
  • 全国公路建设市场信用信息管理系统网站微信营销的特点
  • wordpress控制菜单是否显示网站需要怎么优化比较好
  • 如何做电影网站挣钱爱站网seo工具
  • wordpress福利主题百度网盘优化
  • 网站建设 实训网络营销企业网站优化
  • 湖南张家界建设局网站南京百度推广开户
  • php做电商网站开题报告找网络公司做推广费用
  • 公司网站费用怎么做分录app推广员怎么做
  • 技术外包网站惠州网站推广排名
  • 做购物网站多少钱 知乎品牌设计公司排名前十强
  • 厦门外贸网站找谁最常用的几个关键词
  • 重庆网站建设技术支持重庆互联网百度云搜索引擎官网入口
  • 软件开发公司有几家北京seo关键词
  • 深圳网站公司制作如何看待百度竞价排名
  • 类似wordpress的网站风云榜小说排行榜
  • 用什么工具建设网站白杨seo
  • 如何看出网站用dede做的酒店推广渠道有哪些
  • 南通wap网站建设北京网站优化公司
  • 遵义网站建设制作公司网络推广怎么做
  • 做电影网站需要哪些证爱站工具包的模块
  • 网站如何快速被收录郑州网站定制
  • 重庆开县网站建设报价网站推广 方法
  • 自己怎么优化网站排名宽带营销策略
  • 网站运营与网络推广方案重庆百度推广排名
  • 聊城b2b网站建seo是什么的简称
  • magento网站建设百度智能云官网
  • 建网站一条龙google国外入口
  • 大连建设工程设计院有限公司网站怎样进行seo推广
  • 宁波网站制作公司百度词条优化