从0学习React(3)

server/2024/10/7 18:40:12/

在第一篇文章中,我们对index.tsx文件的每一行代码都做了简单的分析。通过第一篇文章的总结,我也大致知道了index.tsx里的很多语法。而第二篇文章,我对index.tsx文件的框架做了一个大致的分析,通过第二篇文章,我对index.tsx有了进一步的认识。按理来讲,第三篇文章我还是解析index.tsx文件,但是我发现,对于前两篇文章,其实我对语法的细节有很多不明白的点。因此这篇文章,我就把React的一些最基础的知识给梳理一下,帮助我更好的理解index.tsx的代码。

组件基础

首先我们从创建组件开始。创建组件有两种方式:使用函数创建组件或者使用类创建组件。在index.tsx文件中,这两种创建组件的方式都有涉及。

类组件

这就是通过类创建组件。需要注意的是,如果通过类创建组件,那么这个组件必须提供render方法,而且这个方法必须要有return返回值。

函数组件

在render方法中,也用到了通过函数创建组件,看下图:

谈到这里,我发现我对于render渲染方法的结构更加清晰了。

组件中的state

无状态组件和有状态组件

刚刚说了组件有两种,函数组件和类组件。函数组件是无状态组件,只负责展示数据,而类组件属于有状态组件,负责更新用户界面。

state的使用

state,也就是状态。状态是什么?状态其实本质上就是数据,是组件内部的私有数据,只能在组件内部使用。state其实是一个对象,可以包含多个键值对,每个键值对表示组件中的一个数据项。我们说了,组件中的state可以是对象,那就代表着一个组件可以管理多个独立的数据点,而不仅仅是单一的值。

对于类组件,我们一般需要先初始化状态,这样才能够在第一次被渲染的时候,各个组件都有自己的默认state。这就是state被使用的一种方式。

我们一般用(this.state.数据)来获取状态。(this.state.数据)拿的就是组件的最新状态值。比如,如果组件有一个状态叫count,那么this.state.count拿的一定是最新的count值。

我们一般用 this.setState({要求要改的状态},回调函数) 来修改状态,然后更新页面。

关于this.setState方法的详细介绍,我在这篇文章中不详细说,可以看我下一篇文章,因为写的太长会被限流.....


http://www.ppmy.cn/server/128392.html

相关文章

在Git中操作失误,如何撤回

在 Git 中,撤回操作可以通过多种方式实现,具体取决于你想要撤回的操作类型(如提交、暂存、修改等)。以下是几种常见场景及其相应的撤回方法: 1. 撤回未暂存的修改 如果你在工作区中进行了更改,但还没有将…

Java中的Lock、synchronize、CAS关系及其应用场景

目录 第一章 Java中的并发编程基础 1.1 并发编程的基本概念 1.2 线程与进程的关系 1.3 并发编程的挑战与问题 1.3.1 线程安全问题 1.3.2 死锁 1.3.3 竞态条件 第二章 Java中的Lock、synchronize、CAS概述 2.1 Lock的基本概念与分类 2.1.1 Lock接口 2.1.2 Lock的类型…

CompletionFormer 点云补全 学习笔记

目录 依赖项 数据集 KITTI DC NYUv2 提供深度图 模型 依赖项 conda create -n completionformer python3.8 conda activate completionformer # For CUDA Version 11.3 pip install torch1.10.1cu113 torchvision0.11.2cu113 torchaudio0.10.1cu113 pip install mmcv-fu…

学习使用Cube软件

一、点亮LED灯 1、新建项目 File → New → STM32 Project搜索芯片信号项目名称 弹窗点击Yes 2、点亮LED 配置GPIO为输出模式 细化配置 保存(ctrl S)自动生成代码 手动生成代码 选择跳转到代码页面 编译代码 下载代码 设置为自动下载

pytorch之自动求导

在 PyTorch 的 autograd 功能中,主要有几个核心概念和操作: 1. torch.Tensor 和 .requires_grad 属性 torch.Tensor: 这是 PyTorch 中的核心数据结构,类似于 NumPy 数组,但也可用于 GPU 加速计算。.requires_grad: 这是 Tensor …

系统架构设计师论文《论企业应用系统的分层架构风格》精选试读

论文真题 软件架构风格是描述一类特定应用领域中系统组织方式的惯用模式,反映了领域中诸多系统所共有的结构特征和语义特征,并指导如何将各个模块和子系统有效组织成一个完整的系统。分层架构是一种常见的软件架构风格,能够有效简化设计&…

rabbitmq----数据管理模块

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 交换机数据管理管理的字段持久化管理类内存管理类申明交换机删除交换机获取指定交换机 队列数据管理管理的字段持久化管理类内存管理类申明/删除/获取指定队列获取所…

uniapp在线打包的ios后调用摄像头失败的解决方法

uniapp在线打包的ios后调用摄像头失败的解决方法 解决方法: 由于未选中打包模块的配置 当你在测试时发现能够正常的开启摄像头,但是当你对其进行在线打包后,发现当你点击启用摄像头时,没有反应,或者是打开是黑屏状态…