当前位置: 首页 > web >正文

React--函数组件和类组件

React 中的函数组件和类组件是两种定义组件的方式,它们有以下主要区别:

1. 语法与定义方式

  • 函数组件: 是 JavaScript 函数,接收 props 作为参数,返回 JSX。

    const MyComponent = (props) => {return <div>Hello, {props.name}</div>;
    };
    
  • 类组件: 继承自 React.Component,必须定义 render() 方法返回 JSX。

    class MyComponent extends React.Component {render() {return <div>Hello, {this.props.name}</div>;}
    }
    

2. 状态管理

  • 函数组件: 最初无状态,需使用 Hooks(如 useState)管理状态。

    const Counter = () => {const [count, setCount] = useState(0);return <button onClick={() => setCount(count + 1)}>{count}</button>;
    };
    
  • 类组件: 通过 this.state 和 this.setState 管理状态。

    class Counter extends React.Component {state = { count: 0 };increment = () => {this.setState({ count: this.state.count + 1 });};render() {return <button onClick={this.increment}>{this.state.count}</button>;}
    }
    

3. 生命周期方法

  • 函数组件: 使用 useEffect Hook 替代生命周期方法。

    useEffect(() => {// 组件挂载后执行return () => {// 组件卸载前执行};
    }, []); // 依赖项为空数组时,等效于 componentDidMount 和 componentWillUnmount
    
  • 类组件: 有完整的生命周期方法(如 componentDidMount、componentDidUpdate、componentWillUnmount)。

    class MyComponent extends React.Component {componentDidMount() {// 组件挂载后执行}componentWillUnmount() {// 组件卸载前执行}
    }
    

4. 性能优化

  • 函数组件: 通过 React.memo 浅比较 props 避免重复渲染。

    const MyComponent = React.memo((props) => {return <div>{props.value}</div>;
    });
    
  • 类组件: 通过 shouldComponentUpdate 或继承 React.PureComponent 实现。

    class MyComponent extends React.PureComponent {// 自动浅比较 props 和 state
    }
    

5. 上下文与 refs

  • 函数组件: 使用 useContext 和 useRef Hooks。

    const value = useContext(MyContext);
    const ref = useRef(null);
    
  • 类组件: 通过 static contextType 或 Context.Consumer,以及 React.createRef()。

    static contextType = MyContext;
    ref = React.createRef();
    

6. 适用场景

  • 函数组件: 更简洁,适合无状态组件或逻辑简单的组件,是 React 的推荐写法。
  • 类组件: 适合复杂逻辑(如需要访问生命周期方法或使用 this),但逐渐被函数组件替代。

总结

特性函数组件类组件
语法函数 / 箭头函数继承 React.Component
状态管理Hooks(如 useState)this.state 和 setState
生命周期useEffect Hook完整生命周期方法
性能优化React.memoshouldComponentUpdate
适用场景无状态 / 简单逻辑复杂逻辑 / 生命周期依赖

现代 React 开发中,函数组件配合 Hooks 已成为主流,因为它们更简洁、可复用性更高,并且能更好地处理状态和副作用。

http://www.xdnf.cn/news/7840.html

相关文章:

  • DL00987-基于深度学习YOLOv11的红外鸟类目标检测含完整数据集
  • 鸿蒙UI开发——实现一个上拉抽屉效果
  • SQL数据处理流程
  • 使用zap,对web应用/API接口 做安全检测
  • VPX3U规格主板的架构实现与性能评估:飞腾D3000+景嘉微JH930平台
  • 《算法笔记》11.8小节——动态规划专题->总结 问题 G: 点菜问题
  • 域名与DNS详解
  • 操作系统————FCFS(先来先服务),优先级调度,SJF(短作业优先调度),RR(时间片轮转调度)四大算法的c++代码实现
  • NGINX常用功能—笔记
  • MyBatis指定构造
  • 【JVM】学习笔记
  • APM32小系统键盘PCB原理图设计详解
  • Webpack 分包策略详解及实现
  • LangGraph(五)——自定义状态
  • 深入剖析原型模式:原理、实现与应用实践
  • 军工与航空航天特种PCB精密制造:猎板如何定义行业技术新标准?
  • Axure项目实战:智慧运输平台后台管理端-订单管理2(多级交互)
  • opencv的直方图
  • 视频监控联网系统GB28181协议中设备控制流程详解
  • Vue3 中 Route 与 Router 的区别
  • 标准IO(2)、文件IO
  • 华为云Flexus+DeepSeek征文|华为云 Dify LLM 平台单机部署教程:一键开启高效开发之旅
  • PDF处理控件Aspose.PDF教程:以编程方式将PDF转换为Word
  • 用户有一个Django模型没有设置主键,现在需要设置主键。
  • JavaEE 初阶文件操作与 IO 详解
  • 网络安全--PHP第一天
  • 国产linux系统(银河麒麟,统信uos)使用 PageOffice实现PDF文件加盖印章和签字功能
  • 快速刷机Android10+Root
  • OpenCV CUDA模块图像特征检测与描述------图像中快速检测特征点类cv::cuda::FastFeatureDetector
  • CSS【详解】弹性布局 flex