Lazy loaded imageVue2+Vue3前端开发_Day12-Day14_大事件管理系统
2024-9-1
| 2024-9-1
字数 1744阅读时长 5 分钟
type
status
date
slug
summary
tags
category
icon
password
参考课程:
黑马程序员 Vue2+Vue3基础入门到实战项目】
@ZZHow(ZZHow1024)

项目收获

  • Vue3 composition API
  • Pinia / Pinia 持久化处理
  • Element Plus(表单校验,表格处理,组件封装)
  • pnpm 包管理升级
  • Eslint + prettier 更规范的配置
  • husky(Git hooks 工具)代码提交之前,进行校验
  • 请求模块设计
  • VueRouter4 路由设计

创建项目

  • 使用 pnpm 创建项目
      1. pnpm create vue
      1. 选择 Add Vue Router for Single Page Application development、Add Pinia for state management、Add ESLint for code quality 和 Add Prettier for code formatting。
      1. 进入项目目录,安装依赖,启动项目。
  • 配置代码检查工作流
    • 提交前做代码检查
        1. 初始化 Git 仓库,执行 git init
        1. 初始化 Husky 工具配置。
            • 执行 pnpm dlx husky-init && pnpm install
            • 官网:
        1. 修改 .husky/pre-commit 文件。
            • npm test 改为 pnpm lint
      • 问题:默认进行的是全量检查,有耗时问题和历史问题
    • 暂存区 ESLint 校验
        1. 安装 lint-staged 包,执行 pnpm ilint-staged -D
        1. package.json 配置 lint-staged 命令。
          1. 修改 .husky/pre-commit 文件。
              • pnpm lint 改为 pnpm lint-staged
    • 目录调整
      • 默认生成的目录结构不满足我们的开发需求,需要做一些自定义改动。
      • 步骤:
          1. 删除一些初始化的默认文件。
          1. 修改剩余代码内容。
          1. 新增调整我们需要的目录结构。
          1. 拷贝全局样式和图片,安装预处理器支持。

    前置知识

    • Vue Router 4
      • 路由初始化
          1. 创建路由实例由 createRouter 实现。
          1. 路由模式:
            1. history 模式使用 createWebHistory()
            2. hash 模式使用 createWebHashHistory()
            3. 参数是基础路径,默认 /,import.meta.env.BASE_URL 是 Vite 的环境变量。
    • Pinia 构建仓库和持久化
      • 状态管理 - Pinia
        • 用户仓库 - User
        • 持久化 - pinia-plugin-persistedstate
      • 统一管理
        • Pinia 独立维护
        • 仓库统一导出
    • 请求工具设计
      • Axios 配置
        • 创建 Axios 实例:基准地址,超时时间。
        • 请求拦截器:携带 Token。
        • 响应拦截器:业务失败处理,摘取核心响应数据,401 处理。
    • 整体路由设计
      • 登录 - 一级路由
      • 架子 - 一级路由
        • 文章分类 - 二级路由
        • 文章管理 - 二级路由
        • 基本资料 - 二级路由
        • 更换头像 - 二级路由
        • 重置密码 - 二级路由

    项目开发

    • 登录注册
      • 需求:
          1. 注册登录 静态结构&基本切换
          1. 注册功能(校验 + 注册)
          1. 登录功能(校验 + 登录 + 存 Token)
      • 普通校验:
          1. el-form → :model="nuleForm",绑定的整个 form 的数据对象{ xxx, xxx, xxx }。
          1. el-form → :rules="rules",绑定的整个 rules 规则对象 { xxx, xxx, xxx }。
          1. 表单元素 → v-model="ruleForm.xxx",给表单元素,绑定 form 的子属性。
          1. el-form-item → prop 配置生效的是哪个校验规则(和 rules 中的字段要对应)。
      • 自定义校验(校验函数):
        • validator: (rule, value, callback) => {}
            1. rule:当前校验规则相关的信息。
            1. value:所校验的表单元素目前的表单值。
            1. callback:无论成功还是失败,都需要 callback 回调。
        • callback():校验成功。
        • callback (new Error (错误信息)) 校验失败。
      • 预校验
        • await form.value.validate() ,能等到说明校验通过。
      • ESLint 全局变量名
        • 打开文件 .eslintrc.cjs
      • 首页
        • layout 架子
          • 需求:
            • 基本架子拆解(菜单组件的使用)。
            • 登录访问拦截。
            • 用户基本信息获取&渲染。
            • 退出功能 [element-plus 确认框]。
          • el-menu 整个菜单组件:
            • :default-active="$route.path":配置默认高亮的菜单项。
            • router 选项开启,el-menu-ithm 的 index 就是点击跳转的路径。
          • el-menu-item 菜单项:
            • index="/article/channel":配置的是访问的跳转路径。
          • Vue Router 4:
            • 根据返回值决定,是放行还是拦截。
            • 返回值:
              • undefined / true:直接放行。
              • false:拦回 from 的地址页面。
              • 具体路径 或 路径对象:拦截到对应的地址。
        • 文章分类页面 - [element-plus 表格]
          • 需求:
            • 基本架子 - PageContainer 封装。
            • 文章分类渲染 & loading 处理。
            • 文章分类添加编辑[element-plus 弹层]。
            • 文章分类删除。
        • 文章管理页面 - [element-plus 进阶]
          • 需求:
            • 文章列表渲染(带搜索 & 带分页)。
            • 添加文章(糖屉 & 文件上传 & 富文本)。
            • 编辑文章(共用抽屉)。
            • 删除文章。
      • 中文国际化处理
        • 使用 <el-config-providen :locale="zh-cn"> 将需要配置的组件包裹起来
        • 导入中文包:import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
      • 个人中心
        • 基本资料。
        • 更换头像。
        • 重置密码。

      项目演示

    • Vue
    • 学技术
    • Java项目-苍穹外卖_Day1Vue2+Vue3前端开发_Day11
      Loading...