REACT--组件通信

组件之间如何进行通信?

组件通信

组件的通信主要借助props传递值

分为整体接收、解构接收

整体接收
import PropTypes from 'prop-types';//子组件
function Welcome(props){return (<div>hello Welcome,{props.count},{props.msg}</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为字符串类型count: PropTypes.string,// 验证 msg 属性为字符串类型msg: PropTypes.string
};// 父组件
function App(){return (<div>hello App<Welcome count="123" msg="hi react"/></div>)
}export default App

解构接收

import PropTypes from 'prop-types';//子组件
function Welcome({count,msg}){return (<div>hello Welcome,{count},{msg}</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为字符串类型count: PropTypes.string,// 验证 msg 属性为字符串类型msg: PropTypes.string
};// 父组件
function App(){return (<div>hello App<Welcome count="123" msg="hi react"/></div>)
}export default App

传递属性但是不传值,实际传的是true

点击事件:

import PropTypes from 'prop-types';//子组件
function Welcome({onClick,getData}){getData('我是子组件的数据')return (<div onClick={onClick}>hello Welcome</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 onClick 属性为函数类型onClick: PropTypes.func.isRequired,// 验证 getData 属性为函数类型getData: PropTypes.func.isRequired
};// 父组件
function App(){const handleClick =()=>{console.log(1234)}const getData = (data)=>{console.log(data)}return (<div>hello App<Welcome onClick={handleClick} getData={getData}/></div>)
}export default App

 组件内容如何组合到一起

主要是通过props的children属性,传递多组内容只要是大括号可以接收的都可以进行传递,比如样式

通信的数据如何添加默认值和限定类型

通信数据添加默认值:

import PropTypes from 'prop-types';function Welcome({count,msg}){return (<div>hello Welcome,{count},{msg}</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为数字类型count: PropTypes.number,// 验证 msg 属性为字符串类型msg: PropTypes.string
};// 为 Welcome 组件的属性设置默认值
Welcome.defaultProps = {count: 0,msg: 'default content'
};function App(){return (<div>hello App<Welcome count={123} msg="hello react"/><Welcome count={123}/></div>)
}export default App

这样也可以:

import PropTypes from 'prop-types';function Welcome({count=0,msg='default'}){return (<div>hello Welcome,{count},{msg}</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为数字类型count: PropTypes.number,// 验证 msg 属性为字符串类型msg: PropTypes.string
};function App(){return (<div>hello App<Welcome count={123} msg="hello react"/><Welcome count={123}/></div>)
}export default App

 怎么限定类型捏?

很简单,就是使用Protypes

我的版本高格式检测严格都不允许不添加这个勒:

// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为数字类型count: PropTypes.number,// 验证 msg 属性为字符串类型msg: PropTypes.string
};

不添加这个则会强制的报错

 

想要限定多种类型的话可以这样做:

import PropTypes from 'prop-types';function Welcome({count=0,msg='default'}){return (<div>hello Welcome,{count},{msg}</div>)
}// 对 Welcome 组件的属性进行类型验证
Welcome.propTypes = {// 验证 count 属性为数字类型count: PropTypes.oneOfType([PropTypes.string,PropTypes.number,]),// 验证 msg 属性为字符串类型msg: PropTypes.string
};function App(){return (<div>hello App<Welcome count={123} msg="hello react"/><Welcome count={123}/></div>)
}export default App

组件需要是纯函数

 什么是纯函数?

纯函数只负责自己的任务,他不会更改该函数调用前就已经存在的对象或者变量

输入相同,则输出相同,给定相同的输入,纯函数应该总是返回相同的结果,使用严格模式检测不纯的计算

function App({msg}){let count = 0count ++console.log(count)return (<div>hello App,{msg}</div>)
}export default App// 不纯函数
// let bar = 1
// function foo(){
//     bar++
// }
// foo()

组件的状态和useState函数

 瞬间变化的数据被称为状态(state),状态可以进行数据驱动视图,普通变量不行

useState可创建状态和修改状态的方法

状态如何改变视图

为什么普通变量不能呢?是因为无法重新渲染jsx

state状态可行就是因为可以重新触发函数组件,并且state状态具备组件的记忆


import { useState } from "react";
function App(){const [count,setCount] = useState(0)    //可记忆const handleClick = ()=>{setCount(count+1)       //可以重新触发函数组件的执行}console.log(123)return (<div>hello App<button onClick={handleClick}>点击</button>{count}</div>)
}export default App

渲染与提交的过程分为三个步骤

步骤一:触发一次渲染

组件的初次渲染,createRoot().render()

内部状态更新,触发渲染送入队列

步骤二:渲染您的组件

在初次进行渲染的时候,react会调用根组件

内部状态更新会渲染对应的函数组件

步骤三:提交到DOM上

初次渲染,appendChild() DOM API

内部状态更新,更新差异的DOM节点

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

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

相关文章

【排序算法】六大比较类排序算法——插入排序、选择排序、冒泡排序、希尔排序、快速排序、归并排序【详解】

文章目录 六大比较类排序算法&#xff08;插入排序、选择排序、冒泡排序、希尔排序、快速排序、归并排序&#xff09;前言1. 插入排序算法描述代码示例算法分析 2. 选择排序算法描述优化代码示例算法分析 3. 冒泡排序算法描述代码示例算法分析与插入排序对比 4. 希尔排序算法描…

纠错检索增广生成论文

一、摘要 动机&#xff1a;RAG严重依赖于检索文档的相关性&#xff0c;如果检索出错&#xff0c;那么LLM的输出结果也会出现问题 解决方案&#xff1a;提出纠正性检索增强生成&#xff08;CRAG&#xff09;即设计一个轻量级的检索评估器&#xff0c;用来评估针对某个查询检索…

Java NIO与传统IO性能对比分析

Java NIO与传统IO性能对比分析 在Java中&#xff0c;I/O&#xff08;输入输出&#xff09;操作是开发中最常见的任务之一。传统的I/O方式基于阻塞模型&#xff0c;而Java NIO&#xff08;New I/O&#xff09;引入了非阻塞和基于通道&#xff08;Channel&#xff09;和缓冲区&a…

easelog(1)基础C++日志功能实现

EaseLog(1)基础C日志功能实现 Author: Once Day Date: 2025年2月22日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 注&#xff1a;本简易日志组件代码实现参考了Google …

Vue面试2

1.跨域问题以及如何解决跨域 跨域问题&#xff08;Cross-Origin Resource Sharing, CORS&#xff09;是指在浏览器中&#xff0c;当一个资源试图从一个不同的源请求另一个资源时所遇到的限制。这种限制是浏览器为了保护用户安全而实施的一种同源策略&#xff08;Same-origin p…

MongoDB应用设计调优

应用范式设计 什么是范式 数据库范式概念是数据库技术的基本理论&#xff0c;几乎是伴随着数据库软件产品的推出而产生的。在传统关系型数据库领域&#xff0c;应用开发中遵循范式是最基本的要求。但随着互联网行业的发展&#xff0c;NoSQL开始变得非常流行&#xff0c;在许多…

Mac安装配置Tomcat 8

一、官网下载 Index of /disthttps://archive.apache.org/dist/ 1、进入界面如下&#xff1a; 2、我们找到Tomcat文件夹并进入 3、找到Tomcat 8并打开 4、找到对应的版本打开 5、打开bin 6、找到“apache-tomcat-8.5.99.tar.gz”并下载 二、配置Tomcat 1、解压已经下载好的…

【论文精读】VLM-AD:通过视觉-语言模型监督实现端到端自动驾驶

论文地址&#xff1a; VLM-AD: End-to-End Autonomous Driving through Vision-Language Model Supervision 摘要 人类驾驶员依赖常识推理来应对复杂多变的真实世界驾驶场景。现有的端到端&#xff08;E2E&#xff09;自动驾驶&#xff08;AD&#xff09;模型通常被优化以模仿…

百度搜索,能否将DeepSeek变成“内功”?

最近&#xff0c;所有的云平台和主流APP都在努力接入DeepSeek。其中&#xff0c;搜索类APP与搜索引擎更是“战况激烈”。那么问题来了&#xff0c;接入DeepSeek已经变成了标准配置&#xff0c;到底应该如何做出差异化&#xff1f;接入DeepSeek这件事能不能实现11大于2的效果&am…

Flask实现高效日志记录模块

目录 一. 简介&#xff1a; 1. 为什么需要请求日志 二. 日志模块组成 1. 对应日志表创建&#xff08;包含日志记录的关键字段&#xff09; 2. 编写日志记录静态方法 3. 在Flask中捕获请求日志 4. 捕获异常并记录错误日志 5. 编写日志接口数据展示 6. 写入数据展…

25轻化工程研究生复试面试问题汇总 轻化工程专业知识问题很全! 轻化工程复试全流程攻略 轻化工程考研复试真题汇总

轻化工程复试心里没谱&#xff1f;学姐带你玩转面试准备&#xff01; 是不是总觉得老师会问些刁钻问题&#xff1f;别焦虑&#xff01;其实轻化工程复试套路就那些&#xff0c;看完这篇攻略直接掌握复试通关密码&#xff01;文中有重点面试题可直接背~ 目录 一、这些行为赶紧避…

查看已经安装的Python库,高效管理自己的Python开发环境

在日常的Python开发中&#xff0c;掌握如何管理和查看已经安装的库是非常重要的。这不仅能帮助你了解当前项目的依赖关系&#xff0c;还能避免出现版本冲突等问题。在这篇文章中&#xff0c;我们将详细介绍查看已安装Python库的方法&#xff0c;并提供一些实用的工具和技巧。 …

Selenium实战案例1:论文pdf自动下载

在上一篇文章中&#xff0c;我们介绍了Selenium的基础用法和一些常见技巧。今天&#xff0c;我们将通过中国科学&#xff1a;信息科学网站内当前目录论文下载这一实战案例来进一步展示Selenium的web自动化流程。 目录 中国科学&#xff1a;信息科学当期目录论文下载 1.网页内…

Visual Studio Code 2025 安装与高效配置教程

一、软件简介与下载 1. Visual Studio Code 是什么&#xff1f; Visual Studio Code&#xff08;简称VS Code&#xff09;是微软推出的免费开源代码编辑器&#xff0c;支持 智能代码补全、Git集成、插件扩展 等功能&#xff0c;适用于前端开发、Python、Java等多种编程场景。…

工业路由器和工业交换机,打造高效稳定的工业网络?

工业路由器和工业交换机各有千秋&#xff0c;但如何将它们完美结合&#xff0c;构建稳定高效的工业网络&#xff1f;答案就在这里&#xff01; 工业物联网&#xff08;IIoT&#xff09;是高效、稳定的工业网络成为智慧工厂、工业自动化和远程监控等场景的基础支撑。工业路由器…

DeepSeek 助力 Vue 开发:打造丝滑的二维码生成(QR Code)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…

TSMaster【第七篇:千机百变——面板设计艺术】

武侠场景导入&#xff1a;唐门暗器阁的启示 江湖传言&#xff0c;唐门暗器之所以独步天下&#xff0c;全凭其「千机匣」中七十二种机关变化。TSMaster面板设计恰似打造暗器机关——控件如同飞镖、机簧、毒针&#xff0c;组合方式不同则威力迥异。昔日某新势力车型因仪表盘刷新…

提升 AI 服务的稳定性:Higress AI 网关的降级功能介绍

在使用 LLM 服务时&#xff0c;服务的稳定性和可用性至关重要。然而&#xff0c;由于网络问题、服务器故障或其他不可控因素&#xff0c;LLM 服务可能会暂时不可用。为了保障用户体验和业务连续性&#xff0c;Higress AI 网关提供了强大的模型降级和令牌降级功能。本文将介绍这…

提升C++项目编译速度

目录 一、问题背景 二、代码规范方面的解决方案 2.1 拆分头文件 2.2 拆分巨型类 2.3 使用前置声明 2.4 避免在头文件中包含实现 2.5 避免头文件重复包含 2.6 将常用且变动较少的独立到一个文件 三、代码业务重构方面经验 3.1 使用PIMPL&#xff08;Pointer to Imple…

【学术投稿-第四届材料工程与应用力学国际学术会议(ICMEAAE 2025】材料工程与应用力学的探讨

重要信息 官网&#xff1a;www.icmeaae.com 时间&#xff1a;2025年3月7-9日 地点&#xff1a;中国西安 简介 第四届材料工程与应用力学&#xff08;ICMEAAE 2025&#xff09;将于2025年3月7日至9日在中国西安召开。本次会议将重点讨论材料科学、应用力学等领域的最新研究进…