广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >react函数组件对比类组件有哪些优势
  • 426
分享到

react函数组件对比类组件有哪些优势

2024-04-02 19:04:59 426人浏览 安东尼
摘要

这篇文章主要讲解了“React函数组件对比类组件有哪些优势”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react函数组件对比类组件有哪些优势”吧!

这篇文章主要讲解了“React数组件对比类组件有哪些优势”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react函数组件对比类组件有哪些优势”吧!

react函数组件比类组件的优势在:1、函数组件语法更短、更简单,这使得它更容易开发、理解和测试;2、函数式组件性能消耗小,因为函数式组件不需要创建实例,渲染的时候就执行一下,得到返回的react元素后就直接把中间量全部都销毁。

react函数组件对比类组件有哪些优势

教程操作环境:windows7系统、react17.0.1版、Dell G3电脑。

一、类组件

类组件,顾名思义,也就是通过使用es6类的编写形式去编写组件,该类必须继承React.Component

如果想要访问父组件传递过来的参数,可通过this.props的方式去访问

在组件中必须实现render方法,在return中返回React对象,如下:

class Welcome extends React.Component {
	constructor(props) {
		super(props)
	}

	render() {
		return <h2>Hello,{this.props.name}</h2>
	}

二、函数组件

函数组件,顾名思义,就是通过函数编写的形式去实现一个React组件,是React中定义组件最简单的方式

function Welcome(props) {

	return <h2>Hello,{props.name}</h2>;
}

函数第一个参数为props用于接收父组件传递过来的参数

三、区别

针对两种React组件,其区别主要分成以下几大方向:

1、编写形式

两者最明显的区别在于编写形式的不同,同一种功能的实现可以分别对应类组件和函数组件的编写形式

函数组件:

function Welcome(props) {   
return <h2>Hello, {props.name}</h2>; 
}

类组件:

cass Welcome extends React.Component {
	constructor(props) {
		super(props)
	}

	render() {

		return <h2>Hello,{this.props.name}</h2>
	}
}

2、状态管理

在hooks出来之前,函数组件就是无状态组件,不能保管组件的状态,不像类组件中调用setState

如果想要管理state状态,可以使用useState,如下:

const FunctionalComponent=()=> {
	const [count,
	setCount]=React.useState(0);

	return (
	<div> 
	<p>count: {count}</p> 
	<button onClick= {()=> setCount(count + 1)}>Click</button> 
	</div>);
};

在使用hooks情况下,一般如果函数组件调用state,则需要创建一个类组件或者state提升到你的父组件中,然后通过props对象传递到子组件

3、生命周期

在函数组件中,并不存在生命周期,这是因为这些生命周期钩子都来自于继承的React.Component

所以,如果用到生命周期,就只能使用类组件

但是函数组件使用useEffect也能够完成替代生命周期的作用,这里给出一个简单的例子:

const FunctionalComponent=()=> {
	useEffect(()=> {
		console.log("Hello");
	}

	, []);
	return <h2>Hello,World</h2>;
};

上述简单的例子对应类组件中的componentDidMount生命周期

如果在useEffect回调函数中return一个函数,则return函数会在组件卸载的时候执行,正如componentWillUnmount

const FunctionalComponent=()=> {
	React.useEffect(()=> {
		return ()=> {
			console.log("Bye");
		};
	}
	, []);
	return <h2>Bye,World</h2>;
};

4、调用方式

如果是一个函数组件,调用则是执行函数即可:

// 你的代码  
function SayHi() {
	return <p>Hello,
	React</p>
}

// React内部  
const result = SayHi(props) //  <p>Hello, React</p>

如果是一个类组件,则需要将组件进行实例化,然后调用实例对象的render方法:

// 你的代码  
class SayHi extends React.Component {
	render() {
		return <p>Hello,React</p>
	}
}

// React内部  
const instance = new SayHi(props) //  SayHi {}  
const result = instance.render() //  <p>Hello, React</p>

5、获取渲染的值

首先给出一个示例

函数组件对应如下:

function ProfilePage(props) {
	const showMessage=()=> {
		alert('Followed '+ props.user);
	}

	const handleClick=()=> {
		setTimeout(showMessage, 3000);
	}

	return (<button onClick= {
		handleClick
	}

	>Follow</button>)
}

类组件对应如下:

class ProfilePage extends React.Component {
	showMessage() {
		alert('Followed '+ this.props.user);
	}

	handleClick() {
		setTimeout(this.showMessage.bind(this), 3000);
	}

	render() {
		return <button onClick= {
			this.handleClick.bind(this)
		}

		>Follow</button>
	}
}

两者看起来实现功能是一致的,但是在类组件中,输出this.props.user,Props在 React中是不可变的所以它永远不会改变,但是 this 总是可变的,以便您可以在 render 和生命周期函数中读取新版本

因此,如果我们的组件在请求运行时更新。this.props 将会改变。showMessage方法从“最新”的 props 中读取 user

而函数组件,本身就不存在this,props并不发生改变,因此同样是点击,alert的内容仍旧是之前的内容

感谢各位的阅读,以上就是“react函数组件对比类组件有哪些优势”的内容了,经过本文的学习后,相信大家对react函数组件对比类组件有哪些优势这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: react函数组件对比类组件有哪些优势

本文链接: https://www.lsjlt.com/news/95150.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • react函数组件对比类组件有哪些优势
    这篇文章主要讲解了“react函数组件对比类组件有哪些优势”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react函数组件对比类组件有哪些优势”吧! ...
    99+
    2022-10-19
  • React函数组件与类组件使用及优劣对比
    目录一、类组件的问题原因一、因为this带来的问题:问题描述问题解析原因二、类组件代码量比函数组件多:原因三、类组件过于臃肿不易拆分:二、函数组件的问题挂载阶段:getDervied...
    99+
    2022-11-13
  • react类组件和函数组件区别有哪些
    React 类组件和函数组件是两种不同的组件写法,它们之间有以下几个主要区别:1. 语法:React 类组件是通过 ES6 的 cl...
    99+
    2023-10-07
    react
  • React函数组件与类的区别有哪些
    目录一、函数式组件捕获了渲染所用的值二、闭包让类组件成为拥有特定props和state的渲染三、区分useState与useRef的使用首先我们要知道的是,项目性能能主要取决于代码的...
    99+
    2022-11-13
    React函数组件与类 React函数组件
  • hooks函数组件有哪些优缺点
    Hooks函数组件主要有以下优点:1. 更简洁:相比于传统的类组件,Hooks函数组件具有更简洁的写法,可以将组件的逻辑和状态都写在...
    99+
    2023-10-10
    hooks
  • 云服务器ecs的产品组件类型有哪些特点和优势
    云服务器ecs的产品组件主要分为四类: 云服务器ECS:提供了虚拟化技术,通过虚拟化的方式实现资源的划分和管理。例如:Amazon VPC、Google Cloud Elastic Compute、IBM Azure VMware VC...
    99+
    2023-10-26
    组件 优势 类型
  • 云服务器ecs的产品组件类型有哪些特点和优势分析
    云服务器ECS(Elastic Compute Service)是一种云计算服务,它包括了一些产品和组件,可以帮助用户访问和管理各种不同的云计算服务资源。下面是这些产品和组件的一些特点和优势分析: 产品组件: 虚拟化层(Virtua...
    99+
    2023-10-26
    组件 优势 类型
  • 云服务器ecs的产品组件类型有哪些特点和优势是什么
    云服务器ecs的产品组件主要有以下几种类型: 服务器软件:包括服务器集群管理、服务器负载均衡、负载均衡配置等。这些功能通常由服务器硬件、操作系统、数据库和安全软件等多个组件组成。 负载均衡:包括负载均衡软件、负载均衡配置、负载均衡算法、...
    99+
    2023-10-26
    组件 优势 类型
  • Python的数组文件读取方式有哪些优化策略?
    Python作为一门高效的编程语言,拥有丰富的数据处理库和工具。当我们需要处理大量数据时,数组文件的读取和处理就成为了一个重要的问题。Python提供了多种方式来优化数组文件的读取,下面我们将详细介绍这些优化策略并配合演示代码进行说明。 ...
    99+
    2023-07-05
    实时 数组 文件
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作