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

.net core 做网站线上线下一体化营销

.net core 做网站,线上线下一体化营销,怎么利用招聘网站做薪酬调查,企业网站设计推广方案现象 React 中,通常父组件的某个state发生改变,会引起父组件的重新渲染(和其他state的重新计算),从而会导致子组件的重新渲染(和其他非相关属性的重新计算) 问题一:如何避免因为某个…

现象

React 中,通常父组件的某个state发生改变,会引起父组件的重新渲染(和其他state的重新计算),从而会导致子组件的重新渲染(和其他非相关属性的重新计算)

  • 问题一:如何避免因为某个state变化,导致组件的中其他属性(state)的重新计算?

       方案:useMemo

  • 问题二:如何避免因为父组件的重新渲染,导致子组件中非相关属性的重新计算?

       方案:React.memo

结论

总结起来就一句话:

React.memo 用来限制组件重新渲染,而 useMemo 用来限制组件中的部分变量重新计算

(前者主要针对组件的渲染,后者则侧重于组件内的计算)

示例

React.memo:【常用于子组件】

它是一个高阶组件(Higher-Order Component,HOC),用于包装函数组件

当父组件重新渲染时,往往会触发子组件的重新渲染。但很多时候子组件的 props 并没有改变,此时子组件的重新渲染就是不必要的,会造成性能浪费。

经过 React.memo 包装的组件,React 会对其 props 进行浅比较,如果新 props 和旧 props 相同,组件不会重新渲染,而是复用之前的渲染结果。(浅比较只会检查对象或数组的引用是否相同,而不会深入比较其内部的属性或元素)

import React from 'react';// 使用 React.memo 包裹组件
const MyComponent = React.memo(({ data }) => {console.log('组件重新渲染');return <div>{data}</div>;
});const ParentComponent = () => {const [count, setCount] = React.useState(0);const someData = '固定数据';return (<div>{/* 如果子组件不用React.memo包裹,count变化后子组件也会重新渲染 */}<button onClick={() => setCount(count + 1)}>增加计数</button>{/* 只要 someData 不变,MyComponent 不会重新渲染 */}<MyComponent data={someData} /></div>);
};export default ParentComponent;

useMemo

这是一个 React Hook,只能用于函数组件内部

它主要用于缓存计算结果,根据传入的依赖项数组来判断是否需要重新计算缓存的值,避免在每次组件渲染时都进行重复的高开销计算。

如果计算属性作为子组件的 props 传递,且子组件使用 React.memo 进行了优化,在父组件使用 useMemo 可以确保计算属性的引用在依赖项不变时保持稳定,从而避免子组件不必要的重新渲染。

import React, { useState, useMemo, memo } from 'react';const ChildComponent = memo(({ data }) => {console.log('ChildComponent rendered');return <div>{data}</div>;
});const ParentComponent = () => {const [num, setNum] = useState(1);const calculatedData = useMemo(() => {return num * 2;}, [num]);return (<div><inputtype="number"value={num}onChange={(e) => setNum(Number(e.target.value))}/><ChildComponent data={calculatedData} /></div>);
};export default ParentComponent;

这里 calculatedData 通过 useMemo 缓存,当 num 不变时,calculatedData 的引用保持不变,ChildComponent 不会因为 props 的引用变化而重新渲染。

顺便提一下【useCallback】:

当父组件向子组件传递一个函数作为 props,并且子组件使用 React.memo 包裹时,useCallback 可以确保该函数的引用在依赖项不变时保持稳定,从而避免子组件因为函数引用的改变而进行不必要的重新渲染。

import React, { useState, useCallback, memo } from 'react';// 使用 React.memo 包裹子组件
const ChildComponent = memo(({ onClick }) => {console.log('ChildComponent 渲染');return <button onClick={onClick}>点击我</button>;
});const ParentComponent = () => {const [count, setCount] = useState(0);// 使用 useCallback 缓存函数const handleClick = useCallback(() => {setCount(count + 1);}, [count]);return (<div><p>计数: {count}</p><ChildComponent onClick={handleClick} /></div>);
};export default ParentComponent;
http://www.dtcms.com/wzjs/380362.html

相关文章:

  • 厦门app网站建设网络营销方案设计毕业设计
  • 住房和城乡建设部网站政策发布祁阳seo
  • 西安网站制作模板如何写市场调研报告
  • 国内哪个推广网站做的好线上营销推广方案模板
  • 专业网站建设供应商广州aso优化
  • 湛江网站建设方案书seo研究中心怎么样
  • 湖南省建筑工程信息监管平台汕头搜索引擎优化服务
  • 网页游戏开服表的排行榜西安seo推广
  • ps做网站需注意什么属于网络营销特点的是
  • 网站运维服务内容网络平台有哪些?
  • 酒类产品网站设计如何在百度发布广告信息
  • 网站建设服务采购方案模板下载信息如何优化上百度首页
  • dede做视频网站直接下载app
  • 微信公众号开放平台网站seo推广优化教程
  • 网站制作中心市场营销经典案例
  • 网站促销活动策划重庆seo网络推广关键词
  • 专门做高端网站设计的云华设计百度网盘云资源搜索引擎
  • 网站产品链接怎么做的如何开展网络营销活动
  • 关于网站建设的广告语邀请注册推广赚钱
  • 政府网站建设素材收集通知seo主要优化哪些
  • 花都建网站公司网站制作的服务怎么样
  • seo排名赚app下载百度seo2022新算法更新
  • 网站备案更改网站负责人如何进行百度推广
  • 杭州市江干区建设局网站管理方面的培训课程
  • go语言做网站在seo优化中
  • 新手站长如何购买虚拟主机做网站本地免费发布信息网站
  • wordpress多合一百度seo排名点击
  • 视频网站分享复制通用代码怎么做百度怎么优化网站关键词
  • 电子商务网站建设需要学什么软件视频号视频怎么看下载链接
  • 网站集约化建设做法文件外链生成网站