”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Day 组件和 Props - ReactJS

Day 组件和 Props - ReactJS

发布于2024-11-05
浏览:924

Day Components and Props - ReactJS

欢迎来到“ReactJS 30 天”挑战的第四天!今天,我们将探索 Components 和 Props——任何 React 应用程序的构建块。了解这些概念将使您能够将 UI 分解为可重用的独立部分。

什么是组件?

React 中的组件就像菜谱中的成分。正如您组合不同的成分来制作菜肴一样,您也可以组合组件来构建 React 应用程序。组件是一个 JavaScript 函数或类,可以选择接受输入(称为 props)并返回一个描述屏幕上应显示内容的 React 元素。

React中有两种主要类型的组件:

功能组件: 这些是返回 JSX 的 JavaScript 函数。它们更简单、更容易阅读。

类组件: 这些是从 React.Component 扩展的 ES6 类。它们具有更多功能,例如状态和生命周期方法,但在现代 React 开发中不太常见。

示例:按钮组件

让我们创建一个简单的按钮组件:

function Button() {
  return (
    
  );
}

此 Button 组件是一个功能组件,它返回一个带有文本“Click me!”的按钮元素。

为什么组件很重要

组件允许您将 UI 分解为更小的、可管理的部分。这使您的代码更有组织性并且更易于维护。想象一下尝试烹饪一道复杂的菜肴而不将其分解为多个步骤。那就太混乱了!同样,构建没有组件的 UI 可能会变得难以承受。

现实生活中的例子:乐高积木
想想像乐高积木这样的组件。每个块(组件)都是应用程序的一部分,您可以将它们组合起来创建更大的东西。就像乐高积木一样,组件可以在应用程序的不同部分中重复使用。

什么是道具?
Props(“属性”的缩写)是将数据从一个组件传递到另一个组件的方式。它们与函数参数类似,可用于自定义组件。

例如,假设我们要创建一个 Button 组件,它可以根据收到的 props 显示不同的文本:

function Button(props) {
  return (
    
  );
}

现在,当您使用 Button 组件时,您可以传入 label 属性来自定义其文本:

function App() {
  return (
    
); }

此处,Button 组件使用了两次,但具有不同的标签:“提交”和“取消”。

道具的重要性

Props 使您的组件更加灵活和可重用。您可以通过 props 传入动态数据,而不是在组件内硬编码值,从而允许您在不同的上下文中使用相同的组件。

使用Vite设置组件和道具

由于我们使用 Vite 作为开发环境,因此设置组件和 props 非常简单。如果您一直在操作,那么您的 Vite 项目已经配置完毕。您可以开始在单独的文件中创建组件并将它们导入到您的主应用程序中。

以下是构建项目的方法:

1。创建新组件: 在 src 文件夹中创建一个新文件 Button.jsx,并在其中定义 Button 组件。
2.在您的应用程序中使用该组件: 在您的 App.jsx 文件中,导入 Button 组件并将其与不同的 props 一起使用。

把它们放在一起

组件和 props 是 React 基于组件的架构的核心。通过将 UI 分解为更小的组件并使用 props 在它们之间传递数据,您可以构建可扩展且可维护的应用程序。

明天,我们将深入研究状态和生命周期方法,这将使您的组件能够管理动态数据并响应随时间变化的变化。

版本声明 本文转载于:https://dev.to/haquedot/day-4-components-and-props-reactjs-5e8f?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2025-01-14
  • 插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入数据时如何修复“常规错误:2006 MySQL 服务器已消失”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2025-01-14
  • 除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2025-01-14
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2025-01-14
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2025-01-14
  • HTML 格式标签
    HTML 格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-01-14
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2025-01-14
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2025-01-14
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2025-01-14
  • 使用 RAG 掌握查询应答:克服大规模会议数据中的关键挑战
    使用 RAG 掌握查询应答:克服大规模会议数据中的关键挑战
    在信息过载的数字时代,从大型数据集中提取可行的见解比以往任何时候都更加重要。最近,我踏上了利用检索增强生成 (RAG) 来解决一项重大挑战的旅程——从大量会议记录中提供准确的答案。本博客探讨了将我的基于 RAG 的查询应答系统转变为从非结构化会议数据中提取见解的强大工具的障碍、解决方案和成就。 问题...
    编程 发布于2025-01-14
  • 如何准确确定自定义代码和库函数的闰年兼容性?
    如何准确确定自定义代码和库函数的闰年兼容性?
    使用自定义代码和库函数确定闰年兼容性问题:开发一个考虑到复杂的闰年,准确确定给定年份是否为闰年的函数criteria.背景:闰年的典型特征是能被 4 整除。但是,此规则有例外:能被 100 整除的年份不被视为闰年,除非它们能被 400 整除。自定义代码分析:提供的自定义代码似乎遵循闰年标准,但在给定...
    编程 发布于2025-01-14
  • 如何在 Go 测试中可靠地打印调试消息?
    如何在 Go 测试中可靠地打印调试消息?
    如何在 Go 测试中有效打印消息在 Go 中进行测试期间,出于调试目的打印消息可能很有用。但是,使用 fmt.Println 并不总是产生预期的输出。相反,以下方法在使用测试时提供更可靠的打印选项。Testing.T 和 Testing.B 日志记录方法:testing.T 和测试。 B结构体提供以...
    编程 发布于2025-01-14
  • 如何使用基本 PHP 命令合并两个图像?
    如何使用基本 PHP 命令合并两个图像?
    使用 PHP 合并图像:详细指南问题我们如何使用基本的 PHP 命令无缝合并两个图像?请考虑以下示例:图像一:[图像一 URL]图像二:[图像二 URL ]所需结果:[合并图像URL]解决方案要在PHP中合并两个图像,我们可以利用以下方法:创建图像资源:使用 imagecreatefrompng()...
    编程 发布于2025-01-14
  • Go Map 迭代顺序取决于键插入顺序吗?
    Go Map 迭代顺序取决于键插入顺序吗?
    Go Maps 中的赋值顺序考虑以下 Go 代码:package main import "fmt" type Vertex struct { Lat, Long float64 } var m map[string]Vertex func main() { m ...
    编程 发布于2025-01-14
  • 如何在 JDBC 数据库中插入和检索 java.time.LocalDate 对象?
    如何在 JDBC 数据库中插入和检索 java.time.LocalDate 对象?
    在 SQL 数据库中插入和获取 java.time.LocalDate 对象(如 H2)问题: 如何处理 java.time 类型类似于通过 JDBC 使用 SQL 数据库的 LocalDate,例如 H2?Legacy方法: 使用PreparedStatement::setDate 和Result...
    编程 发布于2025-01-14

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3