价格: 29 学币
灵活使用 React ,高效开发健壮、规范的企业级复杂项目
React17 + React Hook + TypeScript4 已成为大型React 项目质量保证的代名词,更是 2021年优秀 React 开发者必备的技术。本课程将通过完成一个功能强大的任务管理项目,带领大家掌握最佳实践,全方位提升开发效率、开发质量和技术能力
第1章 课程介绍(了解本课程必看) 试看
介绍了整个课程的背景知识、能解决什么问题、学完后你将得到什么 ,以及学习方法与 学习前提。
1-1 课程导学 (11:06)试看
1-2 课程源代码下载
第2章 项目起航:项目初始化与配置
本章我们将会⽤Create-React-App初始化项⽬。并配置eslint检验代码质量,prettier检 验代码格式,commitlint检验提交信息,使得⼯程规范化。最后会配置⼀个优秀的后端 Mock⽅案,JSON SERVER 第三、四章使⽤Mock,从第五章开始连接真实服务器。…
2-1 用 Create React App 初始化项目 (07:16)
2-2 配置 eslint、 prettier 和 commitlint 规范工程 (08:56)
2-3 对比常见 Mock 方案 配置 JSON SERVER (10:53)
第3章 React 与 Hook 应用:实现项目列表
本章专注于React,⾸先我们会使⽤React的基础知识:组件、JSX、列表渲染实现⼯程 列表⻚⾯,让⼤家可以回顾React基础知识的使⽤。然后学习⽤状态提升共享组件状态。 最后学习⽤⾃定义Hook抽象代码,并实现第⼀个⾃定义Hook-useDebounce。…
3-1 用 JSX 列表渲染开发工程列表页面 (10:47)
3-2 用状态提升分享组件状态,完成工程列表页面 (20:22)
3-3 学习自定义Hook - 用useDebounce减少工程搜索请求频率 (19:49)
第4章 TS 应用:JS神助攻 - 强类型 试看
本章专注于TS,首先我们会回顾第三章中的JSX代码,发现由于JS天然弱类型带来的脆 弱性。然后⽤TSX改造第三章的JSX代码,增强类型约束,在真实场景中体会TS的优越 性。然后实践TS的进阶知识-泛型,最后通过⼀个作业练习加强⼤家对Hook、TS和泛型 的理解。…
4-1 为什么我们需要TS - 真实场景学习 TS 的必要性 (13:48)试看
4-2 将项目列表页面JS改造成TS,增强类型,减少Bug (16:09)
4-3 TS知识梳理、总结与提高 (21:10)
4-4 学习泛型,用泛型增强useDebounce类型灵活性 (07:25)
4-5 作业练习 - 用 Hook + TS + TS泛型实现useArray (05:52)
4-6 作业解答 - ⽤ Hook + TS + TS泛型实现useArray (03:41)
第5章 JWT、用户认证与异步请求 试看
本章会安装使⽤本课程专属开发者⼯具,连接服务器。还会使⽤JWT实现⽤⼾登录注册 功能,并会抽象出⼀个通⽤异步请求Hook,学会使⽤Context保存全局⽤⼾信息状态。在实现功能的过程中将会应⽤TS的更多⾼级类型知识。
5-1 用React表单、TS的类型继承和鸭子类型实现登录表单 (18:54)
5-2 连接真实服务端 - 专属开发者⼯具介绍与安装 (08:20)
5-3 JWT原理与auth-provider实现 (07:51)
5-4 用useContext存储全局用户信息 (13:49)
5-5 用useAuth切换登录与非登录状态 (06:04)
5-6 用fetch抽象通用HTTP请求方法,增强通用性 (13:15)
5-7 用useHttp管理JWT和登录状态,保持登录状态 (10:04)试看
5-8 TS的联合类型、Partial和Omit介绍 (13:28)
5-9 TS的Utility Types-Pick、Exclude、Partial和Omit实现 (08:58)
第6章 CSS 其实很简单 - 用 CSS-in-JS 添加样式
CSS 是很多同学头疼的技术,本章将会分析传统CSS难以掌握的原因,以及为什么CSS in-JS可以帮助⼤家更有效地掌握CSS,并会安装使⽤antd组件库,⽤Grid和Flexbox布 局⻚⾯,最后优化⻚⾯其他样式。
6-1 安装与使用 antd 组件库 (18:34)
6-2 为什么我们需要CSS-in-JS方案 -通过传统CSS缺陷学习CSS-in-JS必要性 (08:27)
6-3 最受欢迎的CSS-in-JS方案 - Emotion的安装与使用 (15:52)
6-4 用Grid和Flexbox布局优化项目列表页面 (17:57)
6-5 用CSS-in-JS状态工程创建自定义组件:Row组件实现 (07:47)
6-6 完善项目列表页面样式 (10:27)
6-7 清除前面课程留下的警告信息 (11:00)
第7章 用户体验优化 - 加载中和错误状态处理
加载中和错误状态处理是对⽤⼾体验⾮常重要⼀环,本章我们将处理登录注册和项⽬列表 ⻚⾯,并抽象出⼀个通⽤的处理异步操作的Hook-useAsync。最后将学习使⽤React 的⾼级特性 - Error Boundaries 来捕捉渲染错误。
第8章 高级Hook应用 - 项目增删改、与页面标题管理
本章将进⼀步使⽤Hook实现更加复杂的功能。⾸先会⽤useRef和闭包两种⽅案实现 useDocumentTitle来改变⽂档标题。然后结合useAsync与useContext实现项⽬的增 加、修改、删除功能,提⾼⼤家对Hook的使⽤能⼒。
第9章 React 的性能优化与追踪
本章会讲解常⻅的React性能优化⽅法,包括代码分割懒加载,useMemo、useCallback 减少渲染,React Profiler 追踪报告性能等。
第10章 路由与URL状态管理
本章讲解React Router6的使⽤,以及如何⽤Hook获取参数、管理跳转,以及如何⽤ URL进⾏状态管理。
第11章 React Query 与 Redux Toolkit
本章讲解如何使⽤React Query异步获取数据,并使⽤React Query管理服务端状态。还 会使⽤Redux的官⽅库Redux Toolkit来实现状态管理的功能。
第12章 任务看板页面
本章结合前⾯的综合知识开发任务看板⻚⾯,包括任务/看板列表、任务/看板编辑、任 务/看板拖拽等功能。
第13章 任务组页面
本章结合前⾯的综合知识开发任务组⻚⾯,包含任务组列表、任务列表、任务组删除等功 能。
第14章 自动化测试
本章从单元测试、集成测试以及e2e测试三个⽅⾯,综合讲解⾃动化测试的重要性,以及 如何为项⽬ 添加完善的⾃动化测试。
第15章 课程结束
总结回顾整个课程。