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

创新的营销型网站正规拉新推广平台有哪些

创新的营销型网站,正规拉新推广平台有哪些,长沙专门做网站公司,男女做暧暧观看免费网站在 React 中,性能优化是一个重要的主题,特别是在复杂的组件树中。本文将演示如何在同一个父组件中使用 useMemo 和 React.memo 来优化子组件的渲染。 1. 组件结构 创建一个父组件,包含两个子组件: MemoChild:使用 R…

在 React 中,性能优化是一个重要的主题,特别是在复杂的组件树中。本文将演示如何在同一个父组件中使用 useMemoReact.memo 来优化子组件的渲染。

1. 组件结构

创建一个父组件,包含两个子组件:

  • MemoChild:使用 React.memo 进行优化。
  • ExpensiveChild:使用 useMemo 缓存。

示例:

import React, { useState, useMemo } from 'react';// 子组件,使用 React.memo
const MemoChild = React.memo(({ data }) => {console.log('MemoChild rendered');return <div>{data}</div>;
});// 子组件,使用 useMemo 缓存
const ExpensiveChild = ({ data }) => {console.log('ExpensiveChild rendered');return <div>{data}</div>;
};// 父组件
function Parent() {const [count, setCount] = useState(0);const [data, setData] = useState('Initial Data');// 使用 useMemo 来缓存 ExpensiveChildconst memoizedExpensiveChild = useMemo(() => {console.log('Calculating ExpensiveChild');return <ExpensiveChild data={data} />;}, [data]);return (<div><h1>Parent Component</h1><MemoChild data={`Count: ${count}`} />{memoizedExpensiveChild}<button onClick={() => setCount(count + 1)}>Increment Count</button><button onClick={() => setData('New Data')}>Update Data</button></div>);
}export default Parent;

2. 组件功能解析

MemoChild

  • 使用 React.memo 包裹,只有当其 data 属性变化时才会重新渲染。

ExpensiveChild

  • 普通的子组件,父组件使用 useMemo 来缓存其实例。
  • 只有当 data 属性变化时,useMemo 会重新计算并返回新的组件实例。

Parent

  • 管理两个状态:countdata
  • 点击“Increment Count”按钮时,只有 MemoChild 会更新,而 ExpensiveChild 的引用保持不变。
  • 点击“Update Data”按钮时,ExpensiveChild 会重新渲染,因为 data 发生了变化。

3. 运行结果

点击“Increment Count”按钮

  • count 状态更新,MemoChild 会重新渲染,控制台输出:
    MemoChild rendered
    
  • ExpensiveChild 不会重新渲染,控制台不会输出。

点击“Update Data”按钮

  • data 状态更新,ExpensiveChild 会重新渲染,控制台输出:
    Calculating ExpensiveChild
    ExpensiveChild rendered
    

4. useMemoReact.memo 对比:

useMemo

  • Hook钩子函数,用于缓存计算结果。只有当依赖项变化时,才会重新计算。
  • 使用useMemo 缓存 ExpensiveChild 实例,避免不必要的重新渲染。

React.memo

  • 高阶组件,缓存组件的渲染结果。只有当传入的 props 发生变化时,组件才会重新渲染。
  • 适用于根据 props 变化控制渲染的场景。

5. 渲染逻辑总结

基本数据类型(如 numberstringboolean

  • 当组件的 props 是基本数据类型时,如果其值未发生变化,React.memo 不会重新渲染组件。

引用数据类型(如 objectarray

  • 当组件的 props 是引用数据类型时,React.memo 会进行浅比较。
  • 如果引用相同,组件不会重新渲染;如果引用不同,组件会重新渲染。

6. 关键点

  • 基本数据类型的比较:只要值相同,组件不会重新渲染。
  • 引用数据类型的比较:如果引用相同,组件不会重新渲染;如果引用不同(无论内容是否相同),组件会重新渲染。
http://www.fp688.cn/news/157430.html

相关文章:

  • 山西阳泉王平 做网站免费网页在线客服系统
  • 有什么网站专做买生活污水设备360站长平台
  • 易语言怎么用网站做背景音乐网络媒体推广报价
  • 江苏宏澄建设有限公司网站石家庄seo外包公司
  • 微信公众号里怎么做网站灰色seo推广
  • 做网站底部不显示中文怎么回事网站排名推广软件
  • python学习网站长春网站优化页面
  • 义乌建设网站优化排名推广教程网站
  • 做网站哪家比较好百度优化插件
  • 杭州专业的网站制作公司网站排名推广
  • 网站设计贵不贵东莞网络推广公司
  • 宁波网站建设哪家比较好最近一周新闻大事摘抄
  • 网站建设好公司哪家好百度识图搜索引擎
  • 天津票网网站旅游景点推广软文
  • 网站首页修改如何做好网络营销管理
  • 可以自己做安卓app的网站广州百度快速优化排名
  • wordpress伪装成破解成功站长工具seo综合查询5g
  • 网站导航栏怎么做关键词优化排名软件流量词
  • 那个视频网站做公开课比较好市场营销师报名官网
  • 一个网站数据库小升初最好的补课机构排行榜
  • 平面设计软件下载网站网站seo如何做好优化
  • wordpress短代码 下载沧州网站seo
  • 9个做简历的网站网络推广计划制定步骤
  • 哪里有好的免费的网站建设什么企业需要网络营销和网络推广
  • 软件开发用什么工具粤语seo是什么意思
  • 适合用struts2做的网站大连做优化网站哪家好
  • wordpress主题演示百度推广优化工具
  • 佛山营销网站建设百度竞价投放
  • 做图必备素材网站广东百度seo
  • 网站界面设计实训总结关键词指数查询工具