慕课网-真实高质量低代码商业项目,前端/后端/运维/管理系统(前14章)
# 课程介绍:
Vue3 + TS + Egg.js + Nuxt3 开发复杂真实高质量商业项目,前端/后端/运维/管理系统一课打通
# 课程目录:
# 第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)
# 下载地址:
慕课网-真实高质量低代码商业项目,前端/后端/运维/管理系统(前14章)-小白自学网 (opens new window)