码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React82_useCallback()


    为什么需要useCallback?

    接上次讲到的memo,如果说将增加数量的函数从App组件传到A组件,A组件调用此函数来改变App组件的状态,那么App组件将会重新渲染。重新渲染意味着所有的函数和组件将会被重新的创建。因此,会观察到,每次点击按钮都会在控制台显示->        App组件渲染,A组件渲染 

    那么就需要useCallback来缓存这个函数,不至于每次数据更新,函数也要跟着重新创建。 

    React.memo 和 React.useCallback 一定记得需要配对使用,缺了一个都可能导致性能不升反“降”,毕竟无意义的浅比较也是要消耗那么一点点点的性能。 

    使用useCallback

    1. 参数:

            ① 回调函数

            ② 依赖数组

                    Ⅰ 依赖数组里面的数量发生变化,回调函数才会重新渲染

                    Ⅱ 如果不指定依赖数组,回调函数每次都会渲染(跟不用的一样的效果,没有意义)

                    Ⅲ 一定要将回调函数使用到的变量到添加到依赖数组里面,除了setState

    问题

    1. 为什么在useCallback定义的函数体里面使用外部的变量都会不改变,但是setState还是能将外面的改变?

     原因在于setCount

    所以,必须把用的到的东西都放到依赖项里,以至于每次变量改变后,使得函数都会被重新创建。

  • 相关阅读:
    酷开科技 | 酷开系统沉浸式大屏游戏更解压!
    Chapter 15 HMM模型
    Red Hat 6安装Oracle Linux内核头文件
    JS高级(三):严格模式、闭包、递归、深拷贝和浅拷贝
    SpringBoot 09 Web前奏和国际化
    USBCAN 、便携式 CAN 分析仪 、CAN卡
    XSS攻击(2), XSS分类, 测试方法, 防御方法, 绕过方法
    怎么把文件全部重命名并排序递增
    记一次阿里云oss文件上传服务假死
    第二章 JAVA基础语法
  • 原文地址:https://blog.csdn.net/m0_59755550/article/details/126328217
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号