当前位置: 首页 > 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要在最外层 上一次的值要…...

golang web笔记-1.创建Web Server和Handler请求

1. 创建http web server的两个方法 1.1. 方式一&#xff1a;http.ListenAndServe(addr string, handler Handler) addr string&#xff1a;监听地址&#xff0c;如果为"" ,那么就是所有网络接口的80接口handler Handler&#xff1a;如果为nil&#xff0c;那么就是D…...

【Python】Copier:高效的项目模板化工具

Copier 是一个开源的 Python 工具&#xff0c;用于基于项目模板快速生成新项目。它通过灵活的模板化系统&#xff0c;使开发者可以快速创建、维护和更新项目模板&#xff0c;从而自动化项目的初始化流程。无论是简单的文件复制&#xff0c;还是复杂的项目结构配置&#xff0c;C…...

Spring系列 BeanPostProcessor

文章目录 BeanPostProcessor注册时机执行时机 InstantiationAwareBeanPostProcessorSmartInstantiationAwareBeanPostProcessor 本文源码基于spring-beans-5.3.31 参考&#xff1a;https://docs.spring.io/spring-framework/reference/core/beans/factory-extension.html#beans…...

Qualitor processVariavel.php 未授权命令注入漏洞复现(CVE-2023-47253)

0x01 漏洞概述 Qualitor 8.20及之前版本存在命令注入漏洞,远程攻击者可利用该漏洞通过PHP代码执行任意代码。 0x02 复现环境 FOFA&#xff1a;app"Qualitor-Web" 0x03 漏洞复现 PoC GET /html/ad/adpesquisasql/request/processVariavel.php?gridValoresPopHi…...

SpringBoot的概述与搭建

目录 一.SpringBoot的概述 二.SpringBoot 特点 三.SpringBoot 的核心功能 3.1起步依赖 3.2自动配置 四.SpringBoot 开发环境构建 五.SpringBoot 配置文件 六.SpringBoot数据访问管理 七.springboot注解 八.springboot集成mybatis 九.springboot全局异常捕获与处理 一…...

视频集成与融合项目中需要视频编码,但是分辨率不兼容怎么办?

在众多视频整合项目中&#xff0c;一个显著的趋势是融合多元化的视频资源&#xff0c;以实现统一监管与灵活调度。这一需求促使项目团队不断探索新的集成方案&#xff0c;确保不同来源的视频流能够无缝对接&#xff0c;共同服务于统一的调看与管理平台&#xff0c;进而提升整体…...

kafka 换盘重平衡副本 操作流程

一、起因 kakfa某块数据盘损坏&#xff0c;且数据无法恢复&#xff0c;需清空换新盘 二、梳理操作流程 查看topic信息 sh ./kafka-topics --bootstrap-server ***:9092 --list --exclude-internal 查看某个topic数据分布情况 sh ./kafka-topics --bootstrap-server ***:…...

vue3.0 + element plus 全局自定义指令:select滚动分页

需求&#xff1a;项目里面下拉框数据较多 &#xff0c;一次性请求数据&#xff0c;体验差&#xff0c;效果就是滚动进行分页。 看到这个需求的时候&#xff0c;我第一反应就是封装成自定义指令&#xff0c;这样回头用的时候&#xff0c;直接调用就可以了。 第一步 第二步&…...

HarmonyOS/OpenHarmony 离线加载web资源,并实现web资源更新

关键词&#xff1a;h5离线包加载、h5离线包更新、沙箱 在上一篇文章中&#xff0c;我们已经介绍了如何将 rawfile 资源文件中的文件数据拷贝到沙箱下&#xff0c;那么该篇文章将介绍如何加载该沙箱目录下的文件资源&#xff08;此处以打包后的web资源为例&#xff09;&#xf…...

【Spark 实战】基于spark3.4.2+iceberg1.6.1搭建本地调试环境

基于spark3.4.2iceberg1.6.1搭建本地调试环境 文章目录 基于spark3.4.2iceberg1.6.1搭建本地调试环境环境准备使用maven构建sparksql编辑SparkSQL简单任务附录A iceberg术语参考 环境准备 IntelliJ IDEA 2024.1.2 (Ultimate Edition)JDK 1.8Spark 3.4.2Iceberg 1.6.1 使用mave…...

深圳自适应网站建设价格/东莞企业网站排名

最近公司一个项目使用了模块化设计&#xff0c;本人参与其中的一个小模块开发&#xff0c;但是整体的设计并不是我架构设计的&#xff0c;开发半年有余&#xff0c;在此记录下来我的想法。 模块化场景 为什么需要模块化&#xff1f; 当一个App用户量增多&#xff0c;业务量增长…...

wordpress微信缩略图/搜索引擎是软件还是网站

PHP语言是一个短生命周期的Web编程语言&#xff0c;很多PHPer已经形成了fpm下编程的思维定势。实际上在Swoole出现之后&#xff0c;这种串行化编程的模式早已被打破。使用Swoole完全可以轻易实现更灵活的并发编程。 场景介绍 假设我们要做一个石头剪刀布的Web游戏&#xff0c…...

国外开源网站建设软件/seo服务商技术好的公司

这两天在捣鼓ListView widget&#xff0c;为了在ListView中加入Button这类的有 “点击” 事件的widget&#xff0c;请教了不少高手&#xff0c;感谢LandMark对我的认真讲解&#xff0c;下面把解决过程描述一下。ListView 和 其它能触发点击事件的widget无法一起正常工作的原因是…...

it培训骗局/最好的关键词排名优化软件

微信小程序picker异步获取选择项 文章目录微信小程序picker异步获取选择项前言一、微信小程序picker配置二、使用示例wxmljs三、问题点总结***当 range 是一个 Object Array 时&#xff0c;通过 range-key 来指定 Object 中 key 的值作为选择器显示内容关键配置range-key总结前…...

收不到 wordpress 邮件/百度订单售后电话

RDB文件格式一、Redis RDB文件二、解析RDB的高级算法2.1 Magic Number2.2 RDB 版本号2.3 操作码2.3.1 数据库选择器2.3.2 Resizeb信息2.3.3 辅助字段2.3.4 键值对key 到期时间戳值类型键值2.4 CRC64校验码三、编码方式3.1 Length Encoding 长度编码3.2 字符串编码3.2.1 长度前缀…...

使用wordpress的企业/深圳网站设计专家乐云seo

今天一个小伙伴问我&#xff0c;为什么他新装的vscode在使用感叹号!Tab生成html模板的时候不弹出自动生成模板。 然后我上去就是一通操作&#xff0c;英文状态的感叹号不行&#xff0c;就看网上说ctrlshiftp输入change language mode (更改语言模式),选择HTML,再重新输入发现…...