【前端】React回调函数解析

在 React 中,"回调钩子函数"通常指的是把函数作为 回调函数 传递给组件或子组件,然后在特定事件发生时调用它。结合了 React 的事件机制Hook 使用场景。下面详细讲一下:


1️⃣ 基本回调函数

最简单的回调函数示例:

javascript 复制代码
import React from 'react';

const Child = ({ onClick }) => {
  return <button onClick={onClick}>点击我</button>;
};

const Parent = () => {
  const handleClick = () => {
    alert('按钮被点击了!');
  };

  return <Child onClick={handleClick} />;
};

export default Parent;

解释:

  • Parent 定义了回调函数 handleClick
  • handleClick 传给子组件 ChildonClick
  • 子组件在事件触发时调用 onClick,父组件的回调被执行。

2️⃣ 回调函数 + useCallback

当父组件频繁重渲染时,如果回调函数每次都重新创建,可能导致子组件重复渲染或无效依赖。此时可用 useCallback 缓存函数引用:

javascript 复制代码
import React, { useState, useCallback } from 'react';

const Child = React.memo(({ onClick }) => {
  console.log('Child 渲染');
  return <button onClick={onClick}>点击我</button>;
});

const Parent = () => {
  const [count, setCount] = useState(0);

  const handleClick = useCallback(() => {
    alert('按钮被点击了!');
  }, []); // 空依赖,handleClick 引用不会变化

  return (
    <div>
      <button onClick={() => setCount(count + 1)}>父组件加一: {count}</button>
      <Child onClick={handleClick} />
    </div>
  );
};

export default Parent;

解释:

  • useCallback 会缓存函数引用,避免 Child 因父组件渲染而重复渲染。
  • React.memo 用于对子组件做性能优化。

3️⃣ 回调函数 + 参数传递

如果回调需要传参,有两种常见写法:

方法 1:箭头函数

javascript 复制代码
<Child onClick={() => handleClick(123)} />

方法 2:bind

javascript 复制代码
<Child onClick={handleClick.bind(null, 123)} />

4️⃣ 与 React Hook 结合

回调函数常与 useEffectuseState 等 Hook 一起使用,例如:

javascript 复制代码
import React, { useState, useEffect, useCallback } from 'react';

const App = () => {
  const [count, setCount] = useState(0);

  const increment = useCallback(() => {
    setCount(c => c + 1);
  }, []);

  useEffect(() => {
    console.log('组件挂载或 increment 变化');
  }, [increment]);

  return (
    <div>
      <p>count: {count}</p>
      <button onClick={increment}>加一</button>
    </div>
  );
};

export default App;

总结:

  1. 回调函数就是把函数当作参数传递,通常用于子组件事件或异步操作完成后的处理。
  2. 使用 useCallback 可以缓存函数引用,避免不必要的渲染。
  3. 可以配合 React.memouseEffect 等 Hook 做性能优化。
  4. 支持参数传递,可用箭头函数或 bind
相关推荐
NEXT066 分钟前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
剪刀石头布啊12 分钟前
生成随机数,Math.random的使用
前端
剪刀石头布啊13 分钟前
css外边距重叠问题
前端
剪刀石头布啊14 分钟前
chrome单页签内存分配上限问题,怎么解决
前端
剪刀石头布啊16 分钟前
css实现一个宽高固定百分比的布局的一个方式
前端
剪刀石头布啊19 分钟前
js数组之快速组、慢数组、密集数组、稀松数组
前端
mango_mangojuice41 分钟前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
Days20501 小时前
简单处理接口返回400条数据本地数据分页加载
前端
Novlan11 小时前
@tdesign/uniapp 图标瘦身
前端
ManThink Technology1 小时前
如何使用EBHelper 简化EdgeBus的代码编写?
java·前端·网络