React学习笔记(二)——react基础

news2025/1/11 5:19:34

目录

1. 受控表单绑定

2. React中获取DOM

3. 案例:B站评论 — 发表评论

3.1 B站评论案例 —— 核心功能实现

3.2 B站评论案例 — id处理和时间处理

3.3 B站评论案例 — 清空内容并重新聚焦

4. 组件通信

4.1 理解组件通信

4.2 父传子-基础实现

4.3 父传子-props说明

4.4 父传子 - 特殊的prop children

4.5 父子组件通信-子传父

4.6 使用状态提升实现兄弟组件通信

4.7 使用Context机制跨层级组件通信

5. useEffect 的使用

5.1 useEffect 的概念理解

5.2 useEffect 的基础使用

5.3 useEffect 依赖项参数说明

5.4 useEffect — 清除副作用

6. 自定义Hook实现

7. React Hooks使用规则

8. 案例:优化B站评论案例

8.1 优化需求

8.2 优化需求-通过接口获取评论列表

8.3 优化需求-封装评论项Item组件


1. 受控表单绑定

概念:

  • 使用React组件的状态(useState)控制表单的状态

① 准备一个React状态值

② 通过value属性绑定状态,通过onChange属性绑定状态同步的函数

  • 案例:

2. React中获取DOM

在 React 组件中获取/操作 DOM,需要使用 useRef React Hook钩子函数,分为两步:

① 使用useRef创建 ref 对象,并与 JSX 绑定

② 在DOM可用时,通过 inputRef.current 拿到 DOM 对象

  • 案例:

3. 案例:B站评论 — 发表评论

3.1 B站评论案例 —— 核心功能实现

① 获取评论内容
② 点击发布按钮发布评论

3.2 B站评论案例 — id处理和时间处理

① rpid要求一个唯一的随机数id - uuid
  • 使用 uuid 生成随机 id

②  ctime要求以当前时间为标准,生成固定格式 - dayjs
  • dajjs 使用说明文档

3.3 B站评论案例 — 清空内容并重新聚焦

① 清空内容 - 把控制input框的value状态设置为空串
② 重新聚焦 - 拿到input的dom元素,调用focus方法

4. 组件通信

4.1 理解组件通信

概念:
  • 组件通信就是组件之间的数据传递,根据组件嵌套关系的不同,有不同的通信方法

  • A-B 父子通信
  • B-C 兄弟通信
  • A-E 跨层通信

4.2 父传子-基础实现

实现步骤
① 父组件传递数据 - 在子组件标签上 绑定属性
② 子组件接收数据 - 子组件通过 props参数 接收数据

4.3 父传子-props说明

① props可传递任意的数据

  • 数字、字符串、布尔值、数组、对象、函数、JSX

② props是只读对象

  • 子组件只能读取props中的数据,不能直接进行修改, 父组件的数据只能由父组件修改

4.4 父传子 - 特殊的prop children

场景:
  • 当我们把内容嵌套在子组件标签中时,父组件会自动在名为children的prop属性中接收该内容

4.5 父子组件通信-子传父

核心思路:
  • 在子组件中调用父组件中的函数并传递参数

父组件:

子组件:

  • props 是一个对象,相当于 { onGetSonMsg: getMsg }

简写形式:

父组件:

子组件:

  • 解构形参 props

4.6 使用状态提升实现兄弟组件通信

实现思路:
  • 借助“状态提升”机制,通过父组件进行兄弟组件之间的数据传递
① A组件先通过子传父的方式把数据传给父组件App
② App拿到数据后通过父传子的方式再传递给B组件

4.7 使用Context机制跨层级组件通信

实现步骤:
① 使用createContext方法创建一个上下文对象 Ctx,当做组件使用
② 在顶层组件(App)中通过 Ctx.Provider 组件的 value 属性 提供数据
③ 在底层组件(B)中通过 useContext 钩子函数接收 Ctx 上下文对象,获取消费数据
使用Context机制跨层级组件通信使用说明:
  • 顶层组件和底层组件都是相对的

5. useEffect 的使用

5.1 useEffect 的概念理解

useEffect是一个React Hook函数,用于在React组件中 创建不是由事件引起而是 由渲染本身引起的操作(副作用), 比如发送AJAX请求,更改DOM等等
说明:
  • 上面的组件中没有发生任何的用户事件,组件渲染完毕之后就需要和服务器要数据,整个过程属于“只由渲染引起的操作”

5.2 useEffect 的基础使用

需求:
  • 在组件渲染完毕之后,立刻从服务端获取频道列表数据并显示到页面中
语法:
  • 参数1是一个函数,可以把它叫做副作用函数,在函数内部可以放置要执行的操作
  • 参数2是一个数组(可选参),在数组里放置依赖项,不同依赖项会影响第一个参数函数的执行,当是一个空数组的时候,副作用函数只会在组件渲染完毕之后执行一次

5.3 useEffect 依赖项参数说明

useEffect副作用函数的执行时机存在多种情况,根据 传入依赖项的不同 ,会有不同的执行表现

① 没有依赖项。 初始执行一次,组件更新就会执行。也就是 useEffect 的第二个参数为空的情况。

  • 初始化执行一次
  • 只要点击按钮后,组件更新就会执行

② 依赖项为空数组 [],只会执行一次。 组件初始执行一次。

③ 传入特定的依赖项。 初始执行一次,依赖项变化就会执行

  • 也就是 useEffect 的第二个参数依赖某个特定参数
  • 初始化执行一次
  • 只有 count 的值变化的时候才会执行

5.4 useEffect — 清除副作用

在useEffect 中编写的 由渲染本身引起的对接组件外部的操作, 社区也经常把它叫做 副作用操作 ,比如在useEffect中开 启了一个定时器,我们想在组件卸载时把这个定时器再清理掉,这个过程就是清理副作用。
说明:
  • 清除副作用的函数最常见的执行时机是在组件卸载时自动执行
需求:
  • 在Son组件渲染时开启一个定制器,卸载时清除这个定时器

6. 自定义Hook实现

概念:
  • 自定义Hook是以 use 打头的函数,通过自定义Hook函数可以用来实现逻辑的封装和复用

案列:

  • 点击按钮控制元素的显示与隐藏
  • 问题:

    • 布尔切换的逻辑,与当前组件耦合在一起,不方便复用

解决思路自定义 hook

封装自定义 hook 的通用思路:

  • ① 声明一个以 use 开头的函数
  • ② 在函数体内封装可复用的逻辑(只要是可复用的逻辑)
  • ③ 把组件中用到的状态或者回调函数 return 出去(以对象或者数组的形式)
  • ④ 在哪个组件中要用到这个逻辑,就执行这个函数,解构出状态和回调函数进行使用

7. React Hooks使用规则

使用规则
  • 只能在组件中或者其他自定义Hook函数中调用
  • 只能在组件的顶层调用,不能嵌套在 if、for、其他函数中

8. 案例:优化B站评论案例

8.1 优化需求

  • 使用请求接口的方式获取评论列表并渲染
  • 使用自定义Hook函数封装数据请求的逻辑
  • 把评论中的每一项抽象成一个独立的组件实现渲染

8.2 优化需求-通过接口获取评论列表

① 使用 json-server 工具模拟接口服务, 通过 axios 发送接口请求
  • json-server是一个快速以.json文件作为数据源模拟接口服务的工具

  • axios是一个广泛使用的前端请求库

步骤:

  • 安装 json-server 和 axios
  • 评论列表数据转化为 json 字符串,在项目下新建一个 db.json 的文件,将评论列表数据 json 字符串,拷贝到里面。

  • 在 package.json 里的 scripts 节点下配置启动选项,注意端口号 port 不要与项目启动的端口相冲突。

  • 使用命令 npm run serve 启动 json-server 服务器
  • 不要关闭 json-server 服务器,在新的命令窗口启动项目(npm start)
  • http://localhost:3005/defaultList 就是我们请求的 url

② 使用 useEffect 调用接口获取数据
③ 在 App 根组件里调用

8.3 优化需求-封装评论项Item组件

抽象原则:
  • App作为“智能组件”负责数据的获取,Item作为“UI组件”负责数据的渲染

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

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

相关文章

基于Spark计算网络图中节点之间的Jaccard相似性

基于Spark计算网络图中节点之间的Jaccard相似性 Jaccard 相似度是一种较为常用的衡量两个集合相似性的指标,用于计算两个集合的交集与并集的比率。具体来说,它的计算公式为: 在网络图中同样经常使用Jaccard来计算节点之间的相似性&#xff…

【标准知识】航天产品设计文件编号

按照QJ 1714-2011《航天产品设计文件管理制度》,梳理一下设计文件的编号要求。 01 设计文件 按照QJ 1714的规定,设计文件是由设计部门编制的,用以规定产品的组成、型式、结构尺寸、技术要求、原理以及制造、调试、试验、验收、使用、维护、…

Robot Operating System——自定义订阅/发布的消息结构

大纲 初始化环境生成自定义消息的工程创建包自定义消息package.xml完整文件 CMakeLists.txt完整文件 编译注册 使用自定义消息的工程创建包代码CMakeLists.txt编译运行 工程地址参考资料 在之前的案例中我们订阅/发布之间传递的消息都是ROS2的标准类型。本文我们将讨论如何自定…

【IoTDB 线上小课 06】列式写入=时序数据写入性能“利器”?

【IoTDB 视频小课】更新来啦!今天已经是第六期了~ 关于 IoTDB,关于物联网,关于时序数据库,关于开源... 一个问题重点,3-5 分钟,我们讲给你听: 列式写入到底是? 上一期我们详细了解了…

【STM32】写Keil程序的注意事项

看正点原子的资料使用Keil写STM32程序的时候,总是在不断学习,不断探索。后续又学到啥再更新 目录 1 Keil设置 1.1 字体设置 1.2 快捷键设置 1.3 快速前往前一操作位置/后一操作位置 2 宏定义 2.1 宏定义函数时为什么使用do{…}w…

DockerHub解决镜像拉取之困

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:Linux运维老纪的首页…

【数据结构篇】~栈和队列(附源码)

【数据结构篇】~栈和队列 前言一、栈的实现1.头文件2.源文件3.一个算法题——[有效的括号](https://leetcode.cn/problems/valid-parentheses/description/%E2%80%8B) 二、队列1.头文件2.源文件 前言 栈:一种特殊的线性表,其只允许在固定的一端进行插入…

极速文件预览!轻松部署 kkFileView 于 Docker 中!

大家好,这几天闲的难受,决定给自己找点事做。博主的项目中有个文件预览的小需求,原有方案是想将文件转换成 PDF 进行预览。本着能借鉴就绝对不自己写的原则。今天就让我们简单试用一下 kkFileView 文件预览服务,一起探索它的强大功…

先导桌面式教育数控 小型数控车床 C59

桌面式教育数控主要指的是在教育领域中使用桌面型数控机床进行教学和培训。这种设备结合了数控技术和小型化设计,使得数控技术的学习和应用变得更加便捷和经济。 桌面式教育数控的主要特点包括: 小型化:机床体积小,重量轻&#x…

Debezium2.7 数据同步 MySQL/Oracle -- AI生成

Debezium是Red Hat开源的一个工具,用于实时捕获多种数据源(包括MySQL、PostgreSQL、SQL Server、Oracle等)的变更数据,并将这些数据作为事件流输出到Kafka等消息中间件中。通过Debezium,可以实现数据的实时同步和变更数…

Vue组件库Element和Vue路由

目录 一、Vue组件库Element(学会怎么CV) 快速入门 ElementUI的常用组件 1.Table表格 (1)组件演示 (2)组件属性详解 2.Pagination分页 (1)组件演示 (2&#xff0…

易企秀Html5场景秀系统源码 海量模版可以选择 带源代码包以及搭建部署教程

系统概述 易企秀 HTML5 场景秀系统源码是基于 PHPMySQL 组合开发的一套强大的 H5 页面制作系统。它旨在满足企业和个人对于个性化 H5 页面制作的需求,无论是企业宣传、活动推广、产品展示还是邀请函制作等,都能通过该系统轻松实现。 该系统的核心优势在…

智能优化算法-森林优化算法(FOA)(附源码)

目录 1.内容介绍 2.部分代码 3.实验结果 4.内容获取 1.内容介绍 森林优化算法 (Forest Optimization Algorithm, FOA) 是一种基于自然生态系统的元启发式优化算法,它模拟了森林生态系统中的植物生长、竞争和合作等行为,用于解决复杂的优化问题。 FOA的…

uniapp中 使用 VUE3 组合式API 怎么接收上一个页面传递的参数

项目是uniapp &#xff0c;使用了vue3 vite // 使用的组合式API 的 语法糖 <script setup> // 无法使用 onLoad <script> 使用不了下面方法获得上一个页面参数传递 onLoad(options){ } 解决方案1&#xff08;亲测Ok&#xff09;&#xff1a;消息通知与监听…

计算机毕业设计选题推荐-岗位招聘数据可视化分析-Python爬虫

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

Android12 显示框架之Transaction----server端

目录&#xff1a;Android显示终极宝典 上篇讲完了在client端Transaction的内容&#xff0c;最后调用setTransactionState()把所有的参数都交给了surfaceflinger&#xff0c;那么任务就交给server来完成了。本节我们一起接着看看下面的内容。 setTransactionState() //framew…

SQL手工注入漏洞测试(MongoDB数据库)

此次靶场地址为&#xff1a;墨者学院 ⼀. 如下给出的源码...可以看到数据库查询的语句如下..构造回显测试... new_list.php?id1});return ({title:1,content:2 ⼆.成功显示“ 1” 和“ 2” 。可以在此来显示想要查询的数据。接下来开始尝试构造payload查询 当前数据库。通过…

Python基础知识学习总结(七)

文章目录 一. 函数1. 定义函数2. 语法及实例3. 函数调用4. 参数传递5. 可更改与不可更改对象6. 传可变对象实例 二. 文件I/O1. 定义2. File对象的属性3. open 函数4. write()方法5. read()方法6. 文件定位 一. 函数 函数是组织好的&#xff0c;可重复使用的&#xff0c;用来实…

【微服务】SpringCloud Alibaba 10-14章

10 SpringCloud Alibaba入门简介 10.1 是什么 诞生 2018.10.31&#xff0c;Spring Cloud Alibaba 正式入驻了 Spring Cloud 官方孵化器&#xff0c;并在 Maven 中央库发布了第一个版本。 Spring Cloud Alibaba 介绍 10.2 能干嘛 https://github.com/alibaba/spring-cloud-al…

芯片后端之 PT 使用 report_timing 产生报告 之 -nets 选项

今天&#xff0c;我们再学习一点点 后仿真相关技能。 那就是&#xff0c;了解 report_timing 中的 -nets 选项 。 如果我们仅仅使用如下命令&#xff0c;执行后会发现&#xff1a; pt_shell> report_timing -from start_point -to end_point -delay_type max report_ti…