【前端】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
相关推荐
vx_bisheyuange10 分钟前
基于SpringBoot的便利店信息管理系统
前端·javascript·vue.js·毕业设计
晚烛11 分钟前
智启工厂脉搏:基于 OpenHarmony + Flutter 的信创工业边缘智能平台构建实践
前端·javascript·flutter
Zsnoin能13 分钟前
都快2026了,还有人不会国际化和暗黑主题适配吗,一篇文章彻底解决
前端·javascript
两个西柚呀15 分钟前
es6和commonjs模块化规范的深入理解
前端·javascript·es6
www_stdio15 分钟前
爬楼梯?不,你在攀登算法的珠穆朗玛峰!
前端·javascript·面试
光影少年16 分钟前
RN vs Flutter vs Expo 选型
前端·flutter·react native
风止何安啊23 分钟前
🚀别再卷 Redux 了!Zustand 才是 React 状态管理的躺平神器
前端·react.js·面试
鹿角片ljp28 分钟前
Spring Boot Web入门:从零开始构建web程序
前端·spring boot·后端
向下的大树34 分钟前
Vue 2迁移Vue 3实战:从痛点到突破
前端·javascript·vue.js
我很苦涩的35 分钟前
原生小程序使用echarts
前端·小程序·echarts