从0学习React(2)

经过上一篇的文章,对index.tsx文件的每行代码进行了一个简单的分析之后,我大概对React有了一个简单的了解。虽然也是一知半解,但是起码在心里已经对React有了一个基本的概念。这篇文章,我就讲一下关于React中index.tsx的大致框架。

如果把这个文件简单的拆分成2块,那么可以拆分成导入模块和类组件。

导入模块其实没什么好说的,它长这样:

反正就是在开头导入一些必要的东西,这个没啥好讲的,改代码的时候估计也不会改到这里。

我们仔细的研究一下类组件这个模块。其实对于这个模块,又可以将其拆分成几个模块:

初始化state:初始化 state 是设置组件的初始状态值,以便在组件生命周期的早期阶段定义其初始数据结构和默认值。初始化state之后,这个Index组件中的每个小组件都有自己的state,且都有值了。初始化state的代码是这样的:

componentDidMount:只在组件的初次渲染后执行。说实话,其实我到现在还不是很懂为什么需要这个方法。初始化state后,直接进行render渲染,这个时候不都已经渲染好了吗,为什么还要执行这个方法呢?这个方法的代码如下:

第三块就是render渲染中用到的方法。其实用到了很多方法,我没办法一一去解释,我选了一个我比较熟悉的,接触的比较多的方法来讲一下。

onReachBottom方法。

这个方法首先会检查大组件的 loadMore 的状态值是否为noMore,如果是则证明没有更多数据了,那就不需要滚动加载了。接着这个方法会更新大组件的状态。这个更新状态setState有两个参数,第一个参数是要更改的状态,第二个是回调函数。关于对setState这个状态更新,我写过一篇文章,那篇文章很详细的对其做了解释。this.setState({要更改的状态},回调函数)。这里的回调函数涉及到了业务逻辑,我这里不展开细讲。

最后是render渲染。render渲染其实就是把页面渲染出来。

相关推荐
成都渲染101云渲染666615 小时前
Houdini+Blender高效渲染方案(高配算力+全渲染器兼容)
前端·系统架构
SuperEugene15 小时前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
知识分享小能手15 小时前
Redis入门学习教程,从入门到精通, Redis Stack 完整语法知识点及使用指南(7)
数据库·redis·学习
极梦网络无忧16 小时前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
Predestination王瀞潞16 小时前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
爱学习的程序媛16 小时前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr16 小时前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹16 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang16 小时前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端
C羊驼16 小时前
C语言学习笔记(十一):数据在内存中的存储
c语言·经验分享·笔记·学习