【前端】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
相关推荐
JustHappy4 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
snow@li4 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen5 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
小和尚同志5 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.05 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕6 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@6 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#7 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar7 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_471383037 小时前
Taro-02-页面路由
前端·taro