当前位置: 首页 > news >正文

初识React

在最新写需求的时候,我遇到了一个需求,这个需求改后端改的不算多,而且也比较简单,但是在改前端的时候,很复杂。因为我们这个项目用的是React做前端的,而我对于前端知识没有了解,所以理解很多代码都很困难,更别说写了。在我们这个项目中,不仅仅用到了React这么简单,还用到了Taro, TypeScript,Taro UI,ES6+ 语法。但是我觉得一个个去学不成办法,因为这样的话学习周期太长了,而这个需求越快搞定越好。之前睿哥在教我的时候,和我说了这样一句话:“你说你这里不懂,那你为什么不把这里搞懂呢?问AI啊!”所以这次,我也是试着用一种新的方法来学习前端的知识,我选了一个index.tsx文件,遇到不懂的代码就问AI,一条一条的去理解,这样说不定是掌握前端这么多知识的一种方法。

这段代码的意思是:

首先创建一个state对象,state对象包含了多个字段,每个字段都有具体的值。

然后指定state对象的类型为PropsType,PropsType是一个预先定义的TypeScript类型,描述了state对象的结构和字段类型。

接下来,我们研究一下PropsType:

type PropsType = {loadMore: 'more' | 'noMore' | 'loading' | undefined;[key: string]: any;
};
  1. loadMore 字段

    • 必须存在,且其值必须是 'more''noMore''loading' 或 undefined 之一。
  2. 索引签名 [key: string]: any;

    • 允许对象具有任意数量的其他属性。
    • 这些属性的键(key)必须是字符串类型。
    • 这些属性的值(any)可以是任意类型。

所以总结一下这段代码:

  • 创建对象:通过 state: PropsType = { ... },你创建了一个名为 state 的对象。
  • 类型约束:使用 PropsType 类型约束 state 对象,确保它至少包含 loadMore 字段,并且可以包含其他任意数量的字段。

接下来是第二段代码:

这段代码是一个生命周期方法。这段代码展示了一个典型的 React 组件在挂载时进行初始化和事件监听的过程。通过监听路由事件并处理参数,它能够动态地更新组件状态和界面显示。这种模式需要根据路由参数动态更新组件内容。

详细说明
  1. componentDidMount 方法

    • 这是 React 组件的生命周期方法,当组件被挂载到 DOM 中后会立即调用这个方法。
    • 在这里,它首先调用了 this.getBaseDefineOption() 方法,可能是用于初始化一些基础数据。
  2. 监听路由事件

    • 使用 eventCenter.on 方法监听路由的 onShow 事件。
    • 当路由的 onShow 事件被触发时,执行回调函数。
  3. 处理路由参数

    • 在回调函数中,首先获取路由参数 params
    • 如果 params 存在,根据 params 中的 reporterId 和 realExectorId 设置导航栏标题。
    • 使用 this.setState 方法更新组件状态,包括 deviceIddeviceCodereporterId 和 realExectorId
    • 状态更新后,通过回调函数调用 this.getList() 方法获取列表数据。
  4. 无参数处理

    • 如果 params 不存在,直接调用 this.getList() 方法。

这段代码中有几个需要注意的点:

1、if (params.reporterId)中,params.reporterId返回的应该是true或者false,而不是一个具体的数。

2、() => {} 是 JavaScript 中的箭头函数语法。箭头函数是 ES6引入的一种更简洁的函数定义方式。关于箭头函数,最主要的应该就是,箭头函数不会创建自己的 this,它会捕获上下文的 this 值。对于需要在回调中保持 this 上下文的情况非常有用。比如这个代码,这个getList()方法就是下文的,用了this就可以在箭头函数使用了,换句话说getList()方法不是在箭头函数创建的,是从上下文拿的。

接下来看第三段代码:

1. 判断是否还有更多数据

这段代码首先检查 this.state.loadMore 是否等于 'noMore'。如果 loadMore 的值是 'noMore',说明已经没有更多数据可以加载了,方法会立即返回,不会执行后续的代码。

2. 更新状态

this.setState 用于更新组件的状态(state)。loadMore 被设置为 'loading',表示正在加载更多数据。更新 page 对象,将 current 页码加 1,表示要加载下一页的数据。

3. 回调函数

setState 的第二个参数是一个回调函数,在状态更新完成后执行。这个回调函数调用了 this.getList(true) 方法,传递参数 true,通常表示要追加数据到现有列表中,而不是替换现有数据。

接下来看第四段代码:

这段代码定义了一个handleLoading的函数,方便接下来被调用。其中,这里的type是这个意思:

也就是说,在后面调用的时候,你需要传一个参数(true或者false)给handleLoading,然后才能够执行handleLoading()方法。

接下来看第六段代码:

  getList = (type?) => {this.handleLoading(true);const {searchType,deviceCode,deviceId,reporterId,realExectorId,} = this.state;let params: any = {...this.state.page,};if (type && type.execStatus) {params.execStatus = type.execStatus;} else {params.statusSet = searchType;}if (deviceId) {params.deviceId = deviceId;}if (deviceCode) {params.deviceCode = deviceCode;}if (reporterId) {params.reporterId = reporterId;}if (realExectorId) {params.realExectorId = realExectorId;}if (type) {params = {...params,...this.state.page,};}getFaultCenterList(params).then((result) => {if (result?.code === SUCCESS) {if (type) {this.setState({listData: [...this.state.listData, ...result.data.list],loadMore: result.data.list.length > 0 ? 'more' : 'noMore',});} else {this.setState({listData: result.data.list,loadMore: result.data.total <= 10 ? 'noMore' : 'more',actionSheetIsOpen: false,page: { ...this.state.page, current: 1 },});}}this.handleLoading(false);}).catch(() => {this.setState({listData: [],loadMore: 'noMore',});this.handleLoading(false);});};

可以看到getList方法也有一个type,不过type之后有一个问号:

意思应该就是,如果你接下来需要使用getList方法的话,你可以传值,也可以不传值。

这一块是解构赋值。

在我的 getList 方法中,解构赋值的结果可以直接用于构造请求参数 params,从而简化代码。

这一小块代码意思是初始化请求的参数。

这一小块代码意思是,根据 type 参数设置请求的状态参数。如果 type 存在且包含 execStatus 属性,则将其添加到请求参数中;否则,使用 searchType

这块代码的意思是看看有没有其他条件参数,有的话顺便把这些参数添加到params中,没有就跳过这段代码。

这段代码相对复杂一点,

getFaultCenterList(params)//发起请求

相关文章:

初识React

在最新写需求的时候&#xff0c;我遇到了一个需求&#xff0c;这个需求改后端改的不算多&#xff0c;而且也比较简单&#xff0c;但是在改前端的时候&#xff0c;很复杂。因为我们这个项目用的是React做前端的&#xff0c;而我对于前端知识没有了解&#xff0c;所以理解很多代码…...

VUE 开发——AJAX学习(三)

一、async函数和await async和await关键字让我们可以用一种更简洁的方式写出基于Promise的异步行为&#xff0c;而无需刻意地链式调用Promise async写在函数声明的前面&#xff1b;在async函数内&#xff0c;使用await关键字&#xff0c;获取Promise对象“成功状态”结果值 &…...

C++杂项

作业&#xff1a; 将之前实现的顺序表、栈、队列都更改成模板类 顺序表 #include <iostream>using namespace std;template<typename T>class SeqList { private:T *ptr;int size; //总长度int len 0; //当前顺序表实际长度public://初始…...

Gelatinous Cube Sphere - Bonus Files 2 - Atavism

这是Gelatinous Cube & Sphere Pack的奖励文件包。 奖励文件&#xff1a; ⭐ 概念艺术 也可在Monster Bundle #2中使用。 下载&#xff1a;​​Unity资源商店链接资源下载链接...

锐捷—NAT地址映射+IPsec隧道

任务目标 在出口路由器R3上将R5私网地址1对1映射的公网地址与R1建立IPsec隧道&#xff0c;使得R4在访问R5的映射公网地址时&#xff0c;可以进行IPsec隧道的转发 要求&#xff1a; 1、R4和R5可通过NAT转换正常访问互联网地址&#xff08;R2的lo0&#xff09; 2、R5的私网地…...

index.html 调用 ajax

index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>AJAX 请求示例</title><script>// 封装 Ajax 为公共函数&#xff1a;传入回调函数 success 和 failfunction myAjax (url, suc…...

uniapp学习(003-1 vue3学习 Part.1)

零基础入门uniapp Vue3组合式API版本到咸虾米壁纸项目实战&#xff0c;开发打包微信小程序、抖音小程序、H5、安卓APP客户端等 总时长 23:40:00 共116P 此文章包含第11p-第p14的内容 文章目录 vue3使用介绍插值表达式例子时间戳随机数输出函数的值 ref响应式数据变量v-bind 绑…...

计算机毕业设计 基于深度学习的短视频内容理解与推荐系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…...

JavaScript网页设计案例深度解析:从理论到实践

前言 在现代前端开发中&#xff0c;JavaScript 是赋予网页生命的关键技术。静态的 HTML 和 CSS 虽然能创建美观的页面&#xff0c;但当我们需要增强用户交互和页面响应时&#xff0c;JavaScript 无疑成为最得力的工具。从程序员的角度来看&#xff0c;JavaScript 设计不仅仅是…...

spark-sql建表数据同步到hive

1、基础环境 组件版本备注hadoop3.4.0官方下载hive3.1.3自编译sparkspark-3.5.3-bin-hadoop3官方下载&#xff0c;需要内置hive的jar相关内容paimon0.9.0Maven官方下载jdk1.8.0_41maven3.9.6固定版本 2、停止服务、清理日志 先停止&#xff0c;清理数据 sudo kill -9 $(ps -ef…...

Django上下文处理器

1创建 &#xff08;如frontend目录下&#xff09;category_processors文件&#xff1a; def categories(request):from backend.models import Categorycategory_list Category.objects.all()return {category_list:category_list}这里&#xff0c;必须返回一个字典。 2&…...

旭升集团携手纷享销客,构建全方位客户关系管理平台

宁波旭升集团股份有限公司&#xff08;以下简称“旭升集团”&#xff09;自2003年成立&#xff0c;总部位于中国宁波&#xff0c;集团设有压铸、锻造、挤压、集成四大事业部&#xff0c;在亚洲、欧洲、美洲等地均设立研发中心及制造基地&#xff0c;产品主要覆盖新能源汽车的电…...

uniapp 知识点

自定义导航 在page.json navigationstyle":"custom"navigateTo传参 页面传参只能onLoad(option)里面拿 px和upx的关系 在750设计图中&#xff0c;1px1upx 路由 navigateBack返回上一页 重定向 其实就是把当前页面干掉了 公共组件和页面共同点 computed,watc…...

慢病中医药膳养生食疗管理微信小程序、基于微信小程序的慢病中医药膳养生食疗管理系统设计与实现、中医药膳养生食疗管理微信小程序的开发与应用(源码+文档+定制)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…...

解决 Android WebView 无法加载 H5 页面常见问题的实用指南

目录 1. WebView 简介 2. 常见问题 3. 网络权限设置 4. 启用 JavaScript 5. DOM Storage 的重要性 6. 处理 HTTPS 问题 7. 设置 WebViewClient 8. 调试工具 9. 其他调试技巧 10. 结论 相关推荐 1. WebView 简介 Android WebView 是一种视图组件&#xff0c;使得 And…...

Ollama本地部署大模型及应用

文章目录 前言一、下载安装1.Mac2.Windows3.linux4.docker5.修改配置&#xff08;可选&#xff09;1.linux系统2.window 系统3.mac系统 二、Ollama使用1.命令2.模型下载3.自定义模型4.API 服务 三、Open WebUI 使用四、Dify使用 前言 Ollama 是一个专注于本地部署大型语言模型…...

读代码UNET

这个后面这个大小怎么算的&#xff0c;这参数怎么填&#xff0c;怎么来的&#xff1f; 这是怎么看怎么算的&#xff1f; 这些参数设置怎么设置&#xff1f;卷积多大&#xff0c;有什么讲究&#xff1f;...

【java】前端RSA加密后端解密

目录 1. 说明2. 前端示例3. 后端示例3.1 pom依赖3.2 后端结构图3.3 DecryptHttpInputMessage3.4 ApiCryptoProperties3.5 TestController3.6 ApiCryptoUtil3.7 ApiDecryptParamResolver3.8 ApiDecryptRequestBodyAdvice3.9 ApiDecryptRsa3.10 ApiCryptoProperties3.11 KeyPair3…...

机器学习 | Scikit Learn中的普通最小二乘法和岭回归

在统计建模中&#xff0c;普通最小二乘法&#xff08;OLS&#xff09;和岭回归是两种广泛使用的线性回归分析技术。OLS是一种传统的方法&#xff0c;它通过最小化预测值和实际值之间的平方误差之和来找到数据的最佳拟合线。然而&#xff0c;OLS可以遭受高方差和过拟合时&#x…...

代码随想录冲冲冲 Day60 图论Part11

97. 小明逛公园 floyd算法 其实就是先用i和j拼成一个平面 然后看每次从i到j距离 这里分两种情况 1.中间没有经过别的点 2.中间有经过别的点 那么最小步数就要取这两个的最小值 所有根本逻辑是i j确定一个面 再通过不同的k去看每一个中间点 所以k要在最外层 上一次的值要…...

HTML 列表、表格、表单

1 列表标签 作用&#xff1a;布局内容排列整齐的区域 列表分类&#xff1a;无序列表、有序列表、定义列表。 例如&#xff1a; 1.1 无序列表 标签&#xff1a;ul 嵌套 li&#xff0c;ul是无序列表&#xff0c;li是列表条目。 注意事项&#xff1a; ul 标签里面只能包裹 li…...

postgresql|数据库|只读用户的创建和删除(备忘)

CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...

Web 架构之 CDN 加速原理与落地实践

文章目录 一、思维导图二、正文内容&#xff08;一&#xff09;CDN 基础概念1. 定义2. 组成部分 &#xff08;二&#xff09;CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 &#xff08;三&#xff09;CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 &#xf…...

数学建模-滑翔伞伞翼面积的设计,运动状态计算和优化 !

我们考虑滑翔伞的伞翼面积设计问题以及运动状态描述。滑翔伞的性能主要取决于伞翼面积、气动特性以及飞行员的重量。我们的目标是建立数学模型来描述滑翔伞的运动状态,并优化伞翼面积的设计。 一、问题分析 滑翔伞在飞行过程中受到重力、升力和阻力的作用。升力和阻力与伞翼面…...

面试高频问题

文章目录 &#x1f680; 消息队列核心技术揭秘&#xff1a;从入门到秒杀面试官1️⃣ Kafka为何能"吞云吐雾"&#xff1f;性能背后的秘密1.1 顺序写入与零拷贝&#xff1a;性能的双引擎1.2 分区并行&#xff1a;数据的"八车道高速公路"1.3 页缓存与批量处理…...

ArcGIS Pro+ArcGIS给你的地图加上北回归线!

今天来看ArcGIS Pro和ArcGIS中如何给制作的中国地图或者其他大范围地图加上北回归线。 我们将在ArcGIS Pro和ArcGIS中一同介绍。 1 ArcGIS Pro中设置北回归线 1、在ArcGIS Pro中初步设置好经纬格网等&#xff0c;设置经线、纬线都以10间隔显示。 2、需要插入背会归线&#xf…...

MeshGPT 笔记

[2311.15475] MeshGPT: Generating Triangle Meshes with Decoder-Only Transformers https://library.scholarcy.com/try 真正意义上的AI生成三维模型MESHGPT来袭&#xff01;_哔哩哔哩_bilibili GitHub - lucidrains/meshgpt-pytorch: Implementation of MeshGPT, SOTA Me…...

PostgreSQL 与 SQL 基础:为 Fast API 打下数据基础

在构建任何动态、数据驱动的Web API时&#xff0c;一个稳定高效的数据存储方案是不可或缺的。对于使用Python FastAPI的开发者来说&#xff0c;深入理解关系型数据库的工作原理、掌握SQL这门与数据库“对话”的语言&#xff0c;以及学会如何在Python中操作数据库&#xff0c;是…...

react-pdf(pdfjs-dist)如何兼容老浏览器(chrome 49)

之前都是使用react-pdf来渲染pdf文件&#xff0c;这次有个需求是要兼容xp环境&#xff0c;xp上chrome最高支持到49&#xff0c;虽然说iframe或者embed都可以实现预览pdf&#xff0c;但为了后续的定制化需求&#xff0c;还是需要使用js库来渲染。 chrome 49测试环境 能用的测试…...

mcts蒙特卡洛模拟树思想

您这个观察非常敏锐&#xff0c;而且在很大程度上是正确的&#xff01;您已经洞察到了MCTS算法在不同阶段的两种不同行为模式。我们来把这个关系理得更清楚一些&#xff0c;您的理解其实离真相只有一步之遥。 您说的“select是在二次选择的时候起作用”&#xff0c;这个观察非…...