资源链接:
课程介绍:
Vue3 + TS + Egg.js + Nuxt3 开发复杂真实高质量商业项目,前端/后端/运维/管理系统一课打通
在互联网就业形式越来越严峻的今天,掌握多项具有强竞争力的技能非常重要。做一个有完整流程闭环并且有深度有广度的真实项目,可以完美适配这个需求。在这门课程中,我们用最新的技术栈实现了三个独立的项目:前端低代码海报编辑器、后端 egg.js + TS、使用 Nuxt3实现管理系统,最后从 Docker 部署到 CI/CD 的整个流程,最后完美闭环实现一个线上运行的真实项目。大幅提升自己的全栈以及架构能力。
课程目录:
第1章 课程简介
课程简介
1-1 课程导学 (12:30)
第2章 课程设计—需求分析和架构设计:做什么,如何做?
开工之前,先来看看我们到底要做一个什么项目,有哪些功能。然后站在上帝视角,从整体的架构层面,该如何设计该项目。
2-1 需求分析-了解软件开发生命周期 (05:39)
2-2 宏观需求分析 (08:01)
2-3 技术整体架构 – 几个项目,项目的关系 (08:57)
2-4 技术整体架构 – 核心内容分析 (11:16)
第3章 B端项目需求分析 和 架构设计
对于一个复杂前端项目,在编码之前,分析过程可谓是“磨刀不误砍柴工”,本周我们来给大家讲解怎样一步步抽丝剥茧,从需求到难点,再到系统整体设计。
3-1 章简介 (05:22)
3-2 引子:突破瓶颈,前端破局之路 (13:42)
3-3 需求分析 (13:59)
3-4 项目难点分析 (12:25)
3-5 组件库难点解决方案 (11:55)
3-6 编辑器难点解析一 (09:47)
3-7 编辑器难点解析二 (14:36)
3-8 技术选型 – typescript (09:23)
3-9 技术选型 – vue 和 react (11:03)
3-10 总体架构 (08:15)
第4章 前端基础技术回顾和巡礼
在课程正式开始之前,扎实的基础知识是本课程的必备条件。这一周,让我们一起来温习 – typescript,vue3,ant-desing-vue 以及 webpack 和 rollup 的基础知识。
4-1 什么是 Typescript 为什么要学习它 (09:52)
4-2 安装 Typescript (06:06)
4-3 原始数据类型和 Any 类型 (06:07)
4-4 数组和元组 (06:55)
4-5 Interface- 接口 初探 (05:40)
4-6 函数 (07:37)
4-7 类型推论 联合类型和 类型断言 (07:48)
4-8 枚举(Enum) (07:41)
4-9 泛型(Generics) 第一部分 (07:46)
4-10 泛型(Generics) 第二部分 – 约束泛型 (07:06)
4-11 新泛型第三部分 – 泛型在类和接口中的使用 (11:16)
4-12 类型别名,字面量 和 交叉类型 (07:11)
4-13 声明文件 第一部分 (13:34)
4-14 声明文件 第二部分 (10:43)
4-15 内置类型 (08:36)
4-16 Vue3 学习导学 (02:48)
4-17 使用 vite 创建项目 (07:43)
4-18 文件结构以及推荐插件 (13:04)
4-19 ESLint 简介和初步使用 (11:12)
4-20 ESLint 配合 Vite 设置更多规则 (12:45)
4-21 响应式基础 – Ref 和 Reactive (13:08)
4-22 computed 计算属性 (08:30)
4-23 watch 监听器 (13:41)
4-24 生命周期和模版引用 (11:40)
4-25 组件基础-属性 (15:02)
4-26 组件自定义事件 (08:57)
4-27 组合式函数 (10:52)
4-28 创建 useURLLoader (14:41)
4-29 useURLLoader 第二部分 (08:52)
4-30 setup语法第一部分 (05:40)
4-31 setup 语法第二部分 (10:15)
4-32 依赖注入第一部分 (11:17)
4-33 依赖注入第二部分 (11:18)
4-34 Vue3.3 更新简介 (11:38)
第5章 项目整体搭建
万事开头难,本周我们使用技术储备中简介的知识,来搭建项目的大体结构和框架,包括 项目创建,代码结构,基础路由,基本布局和 基本的全局数据结构。
5-1 本章导学 (05:12)
5-2 大话前端工具链 (12:04)
5-3 使用 Imooc CLI 创建项目 (09:06)
5-4 小花絮:Vue CLI 对战 Vite (08:28)
5-5 使用 ESLint 添加代码规范 (07:16)
5-6 深入 ESLint 配置文件 (08:45)
5-7 小花絮:使用 Prettier 自动格式化代码 (09:09)
5-8 项目结构规范 (07:53)
5-9 了解 Git Flow 标准 (10:30)
5-10 安装 ant-design-vue 组件库 (08:24)
5-11 使用 ant-design-vue 搭建页面框架 (09:32)
5-12 SPA 路由的基本原理 (09:41)
5-13 添加配置 Vue Router (08:28)
5-14 使用 Vue Router 钩子函数获取路由信息和跳转 (09:45)
5-15 (打点区间内字小) 使用 Vue Router 元数据和嵌套路由解决不同模版结构 (09:11)
5-16 什么是状态管理工具 (10:23)
5-17 Vuex 安装和基础使用 (07:48)
5-18 Vuex 结合整个应用 (08:56)
5-19 Vuex 添加 mutations 和 getters (08:56)
5-20 使用 Module 分割 Vuex 模块 (08:29)
5-21 第九周总结 (05:53)
第6章 编辑器基本布局,及业务组件库初步开发
本周从编辑器开始开发,完成编辑器的基本布局,并且分析组件属性和修改组件属性的对应关系,创建业务组件库的第一个组件,并且完成最简单的编辑器交互,最后提出了业务组件实时实现编辑更新的解决方案。
6-1 本章导学 (05:10)
6-2 将编辑器数据结构添加至 vuex store (08:01)
6-3 LText 组件初步实现 (10:37)
6-4 LText 添加通用属性 (10:00)
6-5 LText 使用 hooks 重用逻辑 (08:05)
6-6 完成点击模版列表添加到画布的行为 (10:33)
6-7 为业务组件属性添加类型的利弊 (06:19)
6-8 获取正在编辑的元素的属性 (12:19)
6-9 添加属性和表单的基础对应关系并展示 (15:18)
6-10 添加更多简单对应关系并展示 (08:38)
6-11 添加更多复杂对应关系并展示 (09:34)
6-12 分析展示和编辑属性的“金科玉律 (06:27)
6-13 添加编辑表单并更新界面 第一部分 (10:30)
6-14 添加编辑表单并更新界面 第二部分 (08:20)
6-15 提出优化需求,以及组件返回的真相 (07:49)
6-16 将文本转换为 vNode (05:35)
6-17 方案一:使用 JSX 重写 PropsTable 组件 (09:55)
6-18 方案二:使用 render 函数实现桥梁 (06:42)
6-19 本周重点内容回顾和总结 (07:09)
第7章 掌握测试基本工具,给组件库添加单元测试
本周从什么是测试入手,简介了测试的基本概念,介绍通用测试工具 Jest 和 Vue 测试框架 vue-test-utils,然后使用这两种工具完成LText组件的单元测试。
7-1 本章导学 (03:28)
7-2 为什么要有测试 (08:06)
7-3 Jest 简介 (07:53)
7-4 Jest 实现异步测试 (07:38)
7-5 Jest mock 函数测试 (08:08)
7-6 Jest mock 第三方模块实现 (08:33)
7-7 Jest mock Timers (07:09)
7-8 配置测试开发环境 (08:36)
7-9 测试组件:渲染和元素获取 (09:38)
7-10 测试组件:触发事件,更新表单,验证事件 (11:08)
7-11 测试组件:异步请求 (10:08)
7-12 测试通用准备和清理 (06:55)
7-13 测试中 mock 全局组件的实现 (09:48)
7-14 模拟第三方库实现的三种”药方“ – 第一部分 (09:48)
7-15 模拟第三方库实现的三种”药方“ – 第二部分 (07:08)
7-16 单独测试 Vuex store (10:17)
7-17 什么是 TDD 的开发方式 (06:14)
7-18 TDD 第一步:编写测试用例 (10:30)
7-19 TDD 第二布:编写代码实现 (09:52)
7-20 TDD 第三步:和应用整合 (05:59)
7-21 第十一周重点内容回顾和总结 (08:07)
第8章 通用上传组件开发以及使用
本周主要从业务组件 LImage 入手,从易到难使用 TDD 开发一个复杂的通用上传组件,之后将组件用于左侧组件列表中,完成图片组件的功能。
8-1 本章导学 (04:26)
8-2 上传组件需求分析(加片头) (07:32)
8-3 上传文件的原理 (10:41)
8-4 万事开头难 – 编码基本流程 (08:12)
8-5 上传基本流程的测试编写 (10:47)
8-6 编写上传文件列表功能的测试用例 (10:02)
8-7 根据测试实现上传文件列表功能 (13:38)
8-8 编写自定义模版功能的测试用例 (09:12)
8-9 根据测试完成自定义模版功能 (07:05)
8-10 测试驱动开发 – 完成上传前检查的特性 (13:28)
8-11 中期回顾完成情况和新的需求 (07:22)
8-12 新的开发方式:添加拖动上传编码 (11:19)
8-13 添加拖动上传测试 (10:49)
8-14 Vue3 世界中的三种实例 (08:50)
8-15 Vue3 中组件通信的四种方法 (12:10)
8-16 Element Plus Upload 组件源码分析第一部分 (10:02)
8-17 Element Plus Upload 组件源码分析第二部分 (08:18)
8-18 本地图片预览的两种方式 (09:39)
8-19 Jest 浏览器环境之谜 (07:22)
8-20 将上传组件添加到左侧组件列表 (08:56)
8-21 上传图片后将图片组件添加到编辑器 (06:57)
8-22 扩展知识:Element 类型家族之间的关系 (09:00)
8-23 通过 Image 构造函数获取图片的原始大小 (10:12)
8-24 章总结 (06:55)
第9章 业务组件库打包、发布,添加 CI/CD
本周继续丰富业务组件库的功能,将组件库剥离成单独的代码库,使用 rollup 打包成多种 JS 模块形式,发布到 NPM,最后还使用 travis 完成了 CI/CD 流程。
9-1 本章导学 (04:37)
9-2 Javascript 模块化历史 (08:28)
9-3 打包工具的根本作用 (06:23)
9-4 Webpack 对阵 Rollup (09:36)
9-5 打包什么类型的模块 (07:50)
9-6 花絮 – Snowpack 另类打包工具 简介 (10:21)
9-7 创建组件库基本代码结构 (05:52)
9-8 Vue 插件系统简介 (07:57)
9-9 创建入口文件 (06:32)
9-10 Rollup 配置文件和插件 (06:13)
9-11 添加 Vue Plugin (08:52)
9-12 添加 Typescript Plugin (11:56)
9-13 尝试打包入口文件 (11:10)
9-14 生成两种格式的模块文件 (08:11)
9-15 使用 npm link 本地测试组件库 (10:42)
9-16 分析 Element Plus 的打包过程 (09:57)
9-17 扩展知识 – Rollup 插件开发的简单原理 (12:40)
9-18 npm 简介和 package.json 的设置 (07:39)
9-19 使用 npm publish 发布业务组件库 (07:57)
9-20 给业务组件库添加测试用例 (13:24)
9-21 发布或者提交前检查代码质量和测试结果 (08:58)
9-22 什么是 CI CD? (07:53)
9-23 初步配置 travis 完成 CI (08:36)
9-24 进一步配置 travis 完成 CD – 自动发布到 npm (11:14)
9-25 总结 (05:43)
第10章 后端技术选型以及基础知识巩固(上)
在项目开始之前,我们需要根据需求分析完成技术选型。
10-1 14周导学 (05:21)
10-2 接口分析 (09:37)
10-3 后端接口设计文档 (08:39)
10-4 技术选型 express 分析 (09:46)
10-5 了解 express 中间件 (07:58)
10-6 调研 koa2 以及它的基本特点 (09:01)
10-7 koa2 中间件机制 (09:35)
10-8 后端框架选择 egg.js (09:54)
10-9 egg.js 项目结构 (06:52)
10-10 Controller 第一部分:设置响应 (08:03)
10-11 Controller 第二部分:获取 Request 的参数 (09:52)
10-12 Postman安装以及使用 (07:36)
10-13 Service 发送 HTTP 请求获取信息 (08:48)
10-14 Plugin 插件的初次接触 (09:58)
10-15 Middleware 中间件第一部分 (08:41)
10-16 Middleware 中间件第二部分 (09:07)
10-17 Config 配置文件第一部 (11:37)
10-18 Config 配置文件第二部分 (08:12)
10-19 Extend 扩展 第一部分 (07:50)
10-20 Extend 扩展 第二部分 (10:51)
10-21 启动自定义 (12:52)
10-22 egg typescript 支持的原理 (10:31)
10-23 eggjs 调试技巧 (10:14)
10-24 eggjs 日志的概念以及分类 (08:11)
10-25 非关系数据库 对阵 关系型数据库 (08:14)
10-26 mongoDB 安装第一部分:下载运行 (07:48)
10-27 mongoDB 安装第二部分:添加到全局命令 (07:09)
第11章 后端技术选型以及基础知识巩固(下)
后端技术选型以及基础知识巩固(下)
11-1 mongod 使用配置文件 (08:14)
11-2 mongo shell简介及使用 (08:02)
11-3 mongoDB GUI 软件推荐使用 (06:54)
11-4 nodejs 连接 mongodb 数据库 (08:01)
11-5 插入和简单查询 (09:59)
11-6 mongoDB 查询操作符 (11:05)
11-7 mongoDB 整体结果的处理 (07:49)
11-8 更新文档第一部分 (09:07)
11-9 更新文档第二部分:更新数组内容 (09:04)
11-10 按照数组内容查询并更新 (06:59)
11-11 mongoDB Nodejs 语法小节 (10:39)
11-12 mongoDB 索引的定义和测试 (09:45)
11-13 mongoDB 索引管理 (09:00)
11-14 mongoDB 不同集合的数据关系 (07:24)
11-15 聚合的概念和基本用法 (11:26)
11-16 使用$lookup 完成多集合查询 (08:21)
11-17 MongoDB数据库设计原则以及最佳实践 (08:40)
11-18 完成应用数据库设计 (11:10)
11-19 什么是 mongoose 以及 ORM ODM 的概念 (06:46)
11-20 mongoose 基本语法 (11:47)
11-21 egg.js 结合 mongoose (14:03)
11-22 将 models 自动加载到 app 对象 (12:35)
11-23 将逻辑抽象编写为 egg 插件 (10:41)
11-24 egg-mongoose 源代码解读 (13:16)
11-25 章总结 (06:27)
第12章 用户系统设计与实现
正式开始项目,本周我们从实现三种用户登录的实现方式入手,在学习的过程中,引出并学习 Redis,鉴权,Cookie-Session 以及 JWT 和 Oauth2 前后端分离开发啊的实现方式。
12-1 本章导学 (05:27)
12-2 定义 UserModel (08:36)
12-3 实现创建用户的最基本功能 (11:57)
12-4 改进 Model 的ts 类型支持 (10:28)
12-5 使用 egg-validate 验证参数 (11:13)
12-6 规范化错误信息和错误码 (10:31)
12-7 加密选择方案简介 (08:37)
12-8 将 bcrypt 添加到应用并完成密码加密和登录解密 (14:32)
12-9 使用 toJSON 和 transform 处理文档结果 (07:00)
12-10 使用 mongoose-sequence 插件完成 ID 自增 (08:42)
12-11 Cookie基础知识回顾以及加深 (11:13)
12-12 使用 egg.js 设置对应的 Cookie (09:22)
12-13 使用 egg-session 实现用户验证功能 (09:16)
12-14 koa session 源代码分析第一部分 (12:59)
12-15 koa session 源代码分析第二部分 (08:33)
12-16 egg session 使用外部存储器 (09:03)
12-17 总结 egg-session 的优缺点 (08:35)
第13章 文件上传与处理 , SSR 实现 H5 端展示以及权限控制
继续深入项目,这周着重三大块内容,Stream 的学习,HTTP 中文件处理(本地以及云服务),SSR 实现 H5 作品展示,最后使用 Casl 完成 RBAC 用户权限控制。
13-1 本章导学 (04:57)
13-2 文件上传的原理再次分析 (08:31)
13-3 File 模式上传并且支持服务器直接访问 (11:53)
13-4 图片处理库 Sharp 简介 (06:16)
13-5 使用 sharp 生成缩略图并保存 (11:08)
13-6 流的基本概念和举例 (08:39)
13-7 Stream 的基本特性编码 (11:17)
13-8 使用 stream 模式完成图片上传以及缩略图生成 (11:25)
13-9 高级知识:使用 pipeline替换pipe方法 (09:46)
13-10 对象存储调研报告 (08:27)
13-11 配置阿里云 oss (10:36)
13-12 上传单文件到阿里云 OSS (09:16)
13-13 学习底层库 Busboy 的用法 (13:35)
13-14 使用 co-busboy 完成多文件上传的需求 (12:42)
13-15 egg-mutilpart 源代码解析 (12:46)
13-16 限制上传图片大小以及格式 (14:45)
13-17 重构 Router:添加 Prefix 和简单的权限验证 (08:48)
13-18 简介 SSR 的概念和特点 (10:01)
13-19 学习 vue SSR 的基本用法 (08:02)
13-20 使用 lego-components 渲染对应的H5 页面 (12:01)
13-21 添加 body 样式 (07:58)
13-22 px 转换成 vw (11:32)
13-23 使用 webpack 的解决对应的引用第三方库的问题 (05:42)
13-24 配置 webpack 生成对应的结果 (13:13)
13-25 拷贝和清理 webpack 生成的文件 (09:13)
13-26 上传生成的静态文件到 OSS (11:50)
13-27 完成 webpack 结合上传文件到 OSS 的功能 (08:26)
13-28 创建展示渠道 (10:08)
13-29 渠道的更新以及删除 (10:45)
13-30 RBAC概念简介以及选择 Node.js 第三方库 (08:24)
13-31 CASL 初步学习 (09:11)
13-32 CASL 学习第二部分- 添加角色 (08:51)
13-33 CASL学习第三部分 – 管理属性权限 (10:20)
13-34 添加对应的角色模型 (09:55)
13-35 添加角色判断到装饰器第一部分:基本验证 (12:31)
13-36 添加角色判断到装饰器第二部分:验证字段 (10:30)
13-37 添加角色判断到装饰器第三部分:自定义 action (11:43)
13-38 添加角色判断到装饰器第四部分:自定义 query (11:48)
13-39 第十六周总结 (08:09)
第14章 使用 Docker 完成部署以及 Github Actions 完成 CI/CD
项目开发结束,进入应用部署,本章从传统部署到 使用 Docker 以及 docker-compose 完成容器化部署,以及使用 Github Actions 完成 CI/CD 自动部署。
14-1 导学 (06:00)
14-2 本地环境和生产环境的异同 (08:20)
14-3 Node.js Cluster 模式 (10:41)
14-4 Node.js Cluster 压力测试对比结果 (11:09)
14-5 Cluster 进程间的通信 (08:29)
14-6 Egg.js 启动的不同进程的分类以及特点 (10:20)
14-7 云服务器设置以及登录最佳实践 (12:10)
14-8 使用 SSH key 进行免密码登录 (07:09)
14-9 linux 安装必备软件 (11:19)
14-10 修改生产环境的配置 (09:32)
14-11 在服务器部署并且运行 (07:53)
14-12 本章总结以及提出问题 (06:10)
14-13 Docker 简介以及安装 (06:24)
14-14 docker images 镜像操作 (06:24)
14-15 Docker 容器的基本概念 (08:37)
14-16 Docker 容器持久化数据 (10:27)
14-17 使用 Dockerfile 构建镜像 (08:46)
14-18 使用 Dockerfile 构建并且运行 lego-backend (08:44)
14-19 Docker 多个容器互相通信 (09:57)
14-20 使用 docker-compose 启动服务 (11:04)
14-21 mongoDB 设置访问权限 (09:06)
14-22 mongoDB 权限验证第二部分 (07:45)
14-23 Docker 初始化 MongoDB 数据库操作 (14:21)
14-24 使用.env 保存 docker 中的敏感信息 (11:22)
14-25 向 docker-compose 添加 redis 服务并测试 (11:20)
14-26 Docker Build 优化镜像大小 (06:14)
14-27 Docker Build 提高构建速度 (07:23)
14-28 在服务器上运行对应的 docker 容器 (09:55)
14-29 重学 YAML 语法 (06:48)
14-30 Github Actions 简介和初步使用 (13:25)
14-31 学习 Github Actions 的进阶知识 (07:51)
14-32 学习使用 Github Secrets (09:24)
14-33 推送镜像到阿里云ACR 并测试 (07:44)
14-34 优化线上部署流程分析 (07:10)
14-35 使用 Github Actions Build 和 Push 镜像到 ACR (12:34)
14-36 自动部署应用到服务器 第一部分 (11:15)
14-37 自动部署应用到服务器 第二部分 (10:30)
14-38 在 actions 中获取提交的基本信息 (13:10)
14-39 整合流程,完成自动部署以及回滚 (11:00)
14-40 使用 release-it 精简发布流程 (11:34)
14-41 总结 (07:55)