0

0

反应记忆备忘单

DDD

DDD

发布时间:2024-11-04 21:30:13

|

666人浏览过

|

来源于dev.to

转载

反应记忆备忘单

react 提供了三种主要的记忆工具,通过最大限度地减少不必要的重新渲染和重新计算来优化组件性能:

1. usememo – 记忆计算值

  • 用途:缓存计算结果,仅在依赖关系发生变化时重新计算。
  • 用法:用于昂贵的计算派生数据,仅应使用特定依赖项进行更新。

    const memoizedvalue = usememo(() => complexcalculation(), [dependencies]);
    
    
  • 最佳实践

    • 将函数内使用的所有依赖项包含在依赖项数组中。
    • 避免在 usememo 中创建新的引用(数组、对象)或内联函数。
    • 注意:不要将 usememo 用于函数;它缓存值,而不是函数引用。

2. usecallback – memoize 函数参考

  • 用途:缓存函数引用,防止在每次渲染时重新创建。
  • 用法:用于稳定函数引用,特别是用于传递给子组件的回调(例如事件处理程序)。

    简单公司财务系统
    简单公司财务系统

    功能介绍:简单公司日常的办公系统综合管理:权限设置 审批流程 发布公告组织人事:部门设置 员工信息 考勤管理个人办公:未备忘录 通讯录 我的考勤文件管理:公文审批 公共文件 文件收发采购管理:供应商 采购入库 采购退回库存管理:库存设置 库存状况 产品报损 库存调拨销售管理:产品销售 销售退货财务管理:账簿科目 固定资产 固资折旧 工资核算 凭证列表 资产负债 利润损益 现金流量注意:开发环境为V

    下载
    const memoizedfunction = usecallback(() => { /* logic */ }, [dependencies]);
    
    
  • 最佳实践

    • 将函数内使用的所有依赖项包含在依赖项数组中,以避免过时的值。
    • 避免在 usecallback 中声明内联函数,因为这可能会破坏记忆。
    • 注意:仅对函数使用 usecallback。错误地使用 usecallback 来获取值会导致低效的代码和不必要的函数调用。

3. react.memo – 记忆整个组件

  • 用途:如果功能组件的道具未更改,则防止重新渲染。
  • 用法:用于优化子组件,当父组件发生变化时不需要重新渲染。

    const MemoizedComponent = React.memo(ChildComponent);
    
    
  • 最佳实践

    • 与接收稳定 props 或很少更改的 props 的组件一起使用。
    • 避免频繁更改 props(例如新对象/数组),以最大限度地提高 react.memo 的有效性。
    • 注意:与 usecallbackmemoized 函数配合良好,可以维护传递给子组件的稳定 props。

需要记住的要点

  • 使用 usememo 作为值usecallback 作为函数
    • 对函数使用 usememo 会导致立即执行,而不是稳定的函数引用。
    • 对值使用 usecallback 返回一个函数,这会导致代码效率低下,需要额外的函数调用。
  • 记忆总结
    • usememo:缓存计算值(函数的返回值)。
    • usecallback:缓存函数引用(回调)。
    • react.memo:基于 props 缓存 整个组件,以防止父更新重新渲染。
  • 有选择地使用记忆化:正确使用记忆化可以提高性能,但如果过度使用或误用,则会增加复杂性。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号