组件与Props:React中构建可复用UI的基石

目录

组件:构建现代UI的基本单位

Props:组件之间的数据传递

Props的灵活性:构建可配置的组件

组件间的通信:通过回调函数传递数据

总结:


组件:构建现代UI的基本单位

组件是前端开发中的关键概念之一。它允许我们将UI拆分成独立、可复用的部分,使得代码更易于理解、维护和测试。React的组件化方式使得构建复杂的UI变得简单,并且可以轻松地重用和组合不同的组件。

在React中,我们有两种类型的组件:类组件和函数组件。类组件是使用ES6的class语法定义的,而函数组件则是简单的JavaScript函数。无论是类组件还是函数组件,它们都接收props作为参数并返回一段描述UI的JSX代码。

Props:组件之间的数据传递

在React中,props是组件之间进行数据传递的机制。通过props,我们可以将数据从父组件传递给子组件,并在子组件中使用这些数据来渲染UI。Props是只读的,子组件不能直接修改props的值。

在父组件中,我们可以定义props并将其作为属性传递给子组件。子组件可以通过this.props(对于类组件)或props(对于函数组件)来访问这些props的值。

// 父组件 - App.jsimport React from 'react';
import ChildComponent from './ChildComponent';class App extends React.Component {render() {return <ChildComponent name="John" age={25} />;}
}// 子组件 - ChildComponent.jsimport React from 'react';class ChildComponent extends React.Component {render() {return (<div><p>Name: {this.props.name}</p><p>Age: {this.props.age}</p></div>);}
}

在上面的例子中,我们向子组件传递了一个名为name的字符串prop和一个名为age的数字prop。子组件可以使用this.props.namethis.props.age来获取这些值,并在渲染时使用它们。

Props的灵活性:构建可配置的组件

Props不仅仅用于数据传递,还可以使组件更加灵活和可配置。通过改变props的值,我们可以根据需要渲染不同的UI。这种灵活性使得我们能够创建可重用的、可配置的组件,从而提高开发效率。

// 父组件 - App.jsimport React from 'react';
import ChildComponent from './ChildComponent';class App extends React.Component {constructor(props) {super(props);this.state = {showAge: true,};}toggleAge = () => {this.setState(prevState => ({showAge: !prevState.showAge}));};render() {return (<div><button onClick={this.toggleAge}>Toggle Age</button><ChildComponent name="John" age={25} showAge={this.state.showAge} /></div>);}
}// 子组件 - ChildComponent.jsimport React from 'react';class ChildComponent extends React.Component {render() {return (<div><p>Name: {this.props.name}</p>{this.props.showAge && <p>Age: {this.props.age}</p>}</div>);}
}

在这个例子中,我们通过点击按钮来切换子组件中的showAge prop。根据showAge的值,我们决定是否渲染子组件中的年龄信息。这使得我们可以根据需要动态地配置和显示组件的不同部分。

组件间的通信:通过回调函数传递数据

除了传递数据外,我们还可以通过props将回调函数传递给子组件,以实现组件之间的通信。子组件可以调用这些回调函数并将数据作为参数传递回父组件。

// 父组件 - App.jsimport React from 'react';
import ChildComponent from './ChildComponent';class App extends React.Component {constructor(props) {super(props);this.state = {message: ''};}handleMessageChange = (message) => {this.setState({ message });};render() {return (<div><ChildComponent onMessageChange={this.handleMessageChange} /><p>Message: {this.state.message}</p></div>);}
}// 子组件 - ChildComponent.jsimport React from 'react';class ChildComponent extends React.Component {handleChange = (event) => {const message = event.target.value;this.props.onMessageChange(message);};render() {return (<div><input type="text" onChange={this.handleChange} /></div>);}
}

在上面的例子中,子组件包含一个文本输入框,当输入框的值发生变化时,它会调用父组件传递的onMessageChange回调函数,并将新的消息作为参数传递回父组件。父组件通过更新其状态来响应这个回调函数,从而实现了与子组件的通信。

总结:

在本篇博客中,我们了解了React中的组件和props的概念,并探讨了它们在构建现代Web应用程序中的重要性。组件使得我们可以将UI拆分为可复用的部分,而props允许我们在组件之间进行数据传递。通过灵活使用props,我们可以创建可配置的组件,并通过回调函数实现组件之间的通信。希望这篇博客能够帮助您更好地理解组件和props的概念,并在React开发中发挥更大的作用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/129505.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑如何录制小视频

如果你想在你的电脑上录制视频分享给你的朋友或者亲人&#xff0c;无论你的电脑是win还是mac&#xff0c;都可以在本篇文章中找到电脑录制视频的详细教程。小编为你们整理了2种不同系统电脑的录制详细流程&#xff0c;继续阅读查看吧&#xff01; 第一部分&#xff1a;windows…

中国等28个国家发布《布莱切利宣言》,鼓励AI以安全方式发展

英国时间11月1日&#xff0c;中国、美国、英国、法国、德国等28个国家和欧盟&#xff0c;在英国的布莱切利庄园签署了&#xff0c;首个全球性人工智能&#xff08;AI&#xff09;声明——《布莱切利宣言》。 该宣言明确指出了AI对人类社会的巨大机遇&#xff0c;但AI需要以人为…

【C语法学习】16 - fclose()函数

文章目录 1 函数原型2 参数3 返回值4 示例 1 函数原型 fclose()&#xff1a;关闭已打开的文件&#xff0c;并刷新缓冲区&#xff0c;函数原型如下&#xff1a; int fclose(FILE *stream);2 参数 fclose()函数只有一个参数stream&#xff1a; 参数stream是一个指向FILE类型结…

BIOS开发笔记 - CMOS

CMOS原来指的是一种生产电子电路的工艺,在PC上一般指的是RTC电路单元,因为早期它是由这种工艺生产出来的,所以又把RTC称作了CMOS。 RTC(Real Time Clock)即实时时钟,用于保存记录时间和日期,也可以用来做定时开机功能。RTC靠一组独立的电源给它供电,这样设计的目的就是…

直击“挑战杯”竞赛:解锁顶级企业的“创新密码”

“企业只有一项真正的资源——人。” 管理学大师德鲁克&#xff0c;曾发表这样的观点。言外之意&#xff0c;人才是企业发展的根本动力&#xff0c;因为人才可以提供源源不断的创新力。能够基业长青、持续前行的企业&#xff0c;一定在人才上拥有独特优势。 如何吸引人才&#…

Spring cloud负载均衡 @LoadBalanced注解原理

接上一篇文章&#xff0c;案例代码也在上一篇文章的基础上。 在上一篇文章的案例中&#xff0c;我们创建了作为Eureka server的Eureka注册中心服务、作为Eureka client的userservice、orderservice。 orderservice引入RestTemplate&#xff0c;加入了LoadBalanced注解&#x…

Selenium安装WebDriver Chrome驱动(含 116/117/118/119/120/)

1、确认浏览器的版本 在浏览器的地址栏&#xff0c;输入chrome://version/&#xff0c;回车后即可查看到对应版本 2、找到对应的chromedriver版本 2.1 114及之前的版本可以通过点击下载chromedriver,根据版本号&#xff08;只看大版本&#xff09;下载对应文件 2.2 116版本…

一、修改Ubuntu的IP

1、配置虚拟机 三台虚拟机&#xff0c;分别为node1、node2、node3&#xff0c;内存分别为4G、2G、2G&#xff0c;现存最好为&#xff08;>40G&#xff09;&#xff0c;如下&#xff1a; 2、修改主机名 分别打开三台虚拟机&#xff0c;root用户输入一下命令&#xff1a; no…

aardio - 小游戏制作库来了

将 animation 库下载后&#xff0c;解压到 lib\godking\ 目录即可。 附带小游戏代码及素材。 import win.ui; /*DSG{{*/ var winform win.form(text"aardio form";right759;bottom469) winform.add( custom{cls"custom";text"自定义控件";lef…

玩一下Spring Boot

文章目录 1 开发环境1.1 JDK1.2 IntelliJ IDEA2 Spring Boot2.1 创建项目2.2 创建模板页面2.3 创建控制器2.4 启动项目2.5 访问页面1 开发环境 1.1 JDK 安装JDK21 配置环境变量 在命令行查看JDK版本 玩一玩jshell

【三方登录-Apple】iOS 苹果授权登录(sign in with Apple)之开发者配置一

记录一下sign in with Apple的开发者配置 前言 关于使用 Apple 登录 使用“通过 Apple 登录”可让用户设置帐户并使用其Apple ID登录您的应用程序和关联网站。首先使用“使用 Apple 登录”功能启用应用程序的App ID 。 如果您是首次启用应用程序 ID 或为新应用程序启用应用程序…

【PyQt学习篇 · ⑨】:QWidget -控件交互

文章目录 是否可用是否显示/隐藏是否编辑是否为活跃窗口关闭综合案例信息提示状态提示工具提示“这是什么”提示 焦点控制单个控件角度父控件角度 是否可用 setEnabled(bool)&#xff1a;该函数用于设置QWidget控件的可用性&#xff0c;参数bool为True表示该控件为可用状态&…

sqli 靶场 Level23-Level30 wp

level-23 &#xff08;注释被过滤&#xff09; 抓包&#xff0c;查看正常请求和响应。 略 尝试是否存在注入 id1’,id1’&#xff0c;成周期性变化 尝试 POC POC: id1andextractValue(1,concat(0x7e,user()))-- 结果&#xff1a;failed。怀疑–被过滤掉了&#xff0c;尝试…

创建javaEE项目(无maven),JSP(九大内置对象)、Servlet(生命周期)了解

一、Servlet和jsp 0.创建web项目(无maven)&#xff1a; 1.创建一个普通的java项目 2.项目根目录右键&#xff0c;添加模板 3.配置tomcat服务器 4.配置项目tomcat依赖 1.Servlet(Server Applet)服务端小程序 用户通过浏览器发送一个请求&#xff0c;服务器tomcat接收到后&…

基于nodejs+vue 网上商城系统系统-毕业设计

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

乌班图 Linux 系统 Ubuntu 23.10.1 发布更新镜像

Ubuntu 团队在其官网上发布了Ubuntu 23.10.1 版本,这是目前较新的 Ubuntu 23.10(Focal Fossa)操作系统系列的第一个发行版,旨在为社区提供最新的安装媒体。Ubuntu 22.04 LTS(Focal Fossa)操作系统系列于 2022 年 4 月 21 日发布。 Ubuntu 23.10 LTS(长期支持版本)可用…

Win10/Win11总是自动更新,如何关闭自动更新?

参考:https://www.zhihu.com/search?q%E5%85%B3%E9%97%ADwindows%E8%87%AA%E5%8A%A8%E6%9B%B4%E6%96%B0&search_sourceSuggestion&utm_contentsearch_suggestion&typecontent 手动关闭 1 Windows服务 1.1 WinR输入services.msc打开服务 1.2 找到Windows Update…

hugetlb核心组件

1 概述 hugetlb机制是一种使用大页的方法&#xff0c;与THP(transparent huge page)是两种完全不同的机制&#xff0c;它需要&#xff1a; 管理员通过系统接口reserve一定量的大页&#xff0c;用户通过hugetlbfs申请使用大页&#xff0c; 核心组件如下图&#xff1a; 围绕着…

日本it培训学费 想去日本做IT,需要具备哪些技术?

日本的IT行业历史比较悠久&#xff0c;业务以上层前端业务为主&#xff0c;如设计和构建软件。日本IT公司组织庞大&#xff0c;行业内部有着严格的分工和部署&#xff0c;工作会被细分化&#xff0c;分配给个人的工作量不会太大&#xff0c;难度也不会很高&#xff0c;所以日本…

设计模式之装饰模式--优雅的增强

目录 概述什么是装饰模式为什么使用装饰模式关键角色基本代码应用场景 版本迭代版本一版本二版本三—装饰模式 装饰模式中的巧妙之处1、被装饰对象和装饰对象共享相同的接口或父类2、当调用装饰器类的装饰方法时&#xff0c;会先调用被装饰对象的同名方法3、子类方法与父类方法…