zoukankan      html  css  js  c++  java
  • react useCallback的常规使用方式?

    怎么使用好useCallback,来达到减少render次数的效果

    react优化方式

    1. 减少render次数
    2. 减少计算量
    • 下面的代码,当handleClick1时间触发时,PageB组件也会重新渲染
    import React, { memo, useCallback, useState } from 'react'
    
    function PageA (props) {
      const { onClick, children } = props
      console.log(111, props)
      return <div onClick={onClick}>{children}</div>
    }
    
    function PageB ({ onClick, name }) {
      console.log(222)
      return <div onClick={onClick}>{name}</div>
    }
    
    function UseCallback() {
      const [a, setA] = useState(0)
      const [b, setB] = useState(0)
    
      const handleClick1 = () => {
        setA(a + 1)
      }
    
      const handleClick2 =() => {
        setB(b + 1)
      }
    
      return (
        <>
          <PageA onClick={handleClick1}>{a}</PageA>
          <PageB onClick={handleClick2} name={b} />
        </>
      )
    }
    
    export default UseCallback
    
    • 使用useCallback进行处理
    1. 点击事件handleClick1触发时,PageB组件也会重新渲染,当PageB组件比较耗时时,就会造成新能问题
    2. PageB组件重新渲染的原因在于每次重新渲染,onClick都会重新定义,即上次的与这次的不一致
    3. 思路:通过useCallback包裹onClick来达到缓存的效果,即useCallback的依赖项不变时不重新生成
    4. 用过memo方法包裹PageB组件,并且通过useCallback包裹PageB组件的onClick方法,memo与PureComponent比较类似,前者是对Function Component的优化,后者是对Class Component的优化,都会对传入组件的数据进行浅比较,useCallback则会保证handleClick2不会发生变化
    import React, { memo, useCallback, useState } from 'react'
    
    function PageA (props) {
      const { onClick, children } = props
      console.log(111, props)
      return <div onClick={onClick}>{children}</div>
    }
    
    function PageB ({ onClick, name }) {
      console.log(222)
      return <div onClick={onClick}>{name}</div>
    }
    
    const PageC = memo(PageB)
    
    function UseCallback() {
      const [a, setA] = useState(0)
      const [b, setB] = useState(0)
    
      const handleClick1 = () => {
        setA(a + 1)
      }
    
      const handleClick2 = useCallback(() => {
        setB(b + 1)
      }, [b])
    
      return (
        <>
          <PageA onClick={handleClick1}>{a}</PageA>
          <PageC onClick={handleClick2} name={b} />
        </>
      )
    }
    
    export default UseCallback
    
  • 相关阅读:
    有了这个算法,图像上文字擦除再也用不上PS了
    说说Golang goroutine并发那些事儿
    Redis Sentinel 源码:Redis的高可用模型分析
    从架构设计理念到集群部署,全面认识KubeEdge
    如何极速极速搭建个人博客?Copy攻城狮用的这一招很优秀!
    Python进阶丨如何创建你的第一个Python元类?
    逼疯UE设计师,不可不知的提升产品用户体验的10个测试方法
    一文总结GaussDB通信原理知识
    目标检测推理部署:优化和部署
    GPU上的快速光谱图分区
  • 原文地址:https://www.cnblogs.com/sk-3/p/13808854.html
Copyright © 2011-2022 走看看