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

React中的函数组件与类组件

在React中,有两种不同的组件形式:函数组件和类组件。它们的写法并不相同。

函数组件

React的函数组件是一个只接受 props 参数并返回元素的 JavaScript 函数(该props与Vue中props一样是只读的,且都是父组件传递给子组件的数据)。

export function MyComponent(props) { // 不同于Vue中的函数组件(有props和ctx两个参数)
  return <h1>{ props.hobby }</h1>;
}

函数式组件自身没有任何状态(state)生命周期方法,只接受其父组件传递的数据(props)。

类组件

类组件使用class关键字定义,组件名格式必须是大驼峰,且继承于React.component

class MyComponent extends React.Component {
	constructor(props) {
		super(props); // 也可以接受props
		this.state = {} // 组件的状态(响应式状态)
		// 必须为类组件中的方法显示绑定this(法一),否则在经过babel的转化后(严格模式下)函数方法的this指向undefined
		this.[methodName1] = this.[methodName1].bind(this);
	}
	[methodName1]() {} // 类组件的方法
	// 箭头函数没有自己的this,因此会使用上层作用域的this
	[methodName2] = () => {}
	[methodName3]() {} 
	// render函数中的this默认指向组件实例
	render() { // 类组件固定方法,返回要渲染的内容(jsx)
		return (
			<> // 等同于<Fragment></Fragment>,不过Fragment上可以写key
				<h1>Hello, { this.props.name }</h1>
				<button onClick={this.[methodName1]}>点击按钮</button>
				{/* 或者在jsx中为类组件中的方法显示绑定this(法一) */}
				{/* <button onClick={this.[methodName1].bind(this)}>点击按钮</button> */}
				<button onClick={this.[methodName2]}>点击按钮</button>
				<button onClick={() => this.[methodName3]()}>点击按钮</button>
			</>
		);
  }
}

因此,函数组件和类组件的主要区别是:函数组件没有任何状态(state)和生命周期方法(因为生命周期方法来源于React.component),且函数组件中不会使用this。不过,函数组件可以在使用React中的Hooks时使用state


http://www.kler.cn/a/353994.html

相关文章:

  • Vue2/Vue3使用DataV
  • 简易Type-C拉取5V/3A电流电路分享
  • 数据库进阶教程之DDL语句(万字详解)
  • 250103-逻辑运算符
  • SQLALchemy如何将SQL语句编译为特定数据库方言
  • Python应用指南:高德交通态势数据
  • 【Bug】docker容器之间网络通讯失败
  • 在vue中v-show不起作用
  • Axure重要元件三——中继器表单制作
  • 图书管理智能化:Spring Boot进销存系统
  • Spring如何通过三级缓存解决循环依赖的问题
  • 5G对无人机的影响!
  • 简述RESTFul风格的API接口
  • 【Git】基本操作+分支管理
  • 探索社交网络中的情感脉动 | 微博评论舆情分析系统
  • Cesiumlab发布3dtiles白膜流程与前端可视化加载
  • 基于SpringBoot的课程辅助教学系统
  • 信息收集笔记
  • 基于卷积神经网络的蔬菜识别系统,resnet50,mobilenet模型【pytorch框架+python源码】
  • 安装mysql 5.5.62
  • 【人工智能】实验室GPU资源申请使用
  • 视频云存储/音视频流媒体视频平台EasyCVR视频汇聚平台在欧拉系统中启动失败是什么原因?
  • 3-4 AUTOSAR RTE对CS Port的实现
  • 人脸识别-特征算法
  • HarmonyOS preferences存储
  • SwiftUI 6.0(iOS 18)自定义容器值(Container Values)让容器布局渐入佳境(上)