Vue3+Ts+Vite -- 后台管理项目

1.搭建环境及配置文件

        配置vue组件的类型 env.t.ts

/// <reference types="vite/client" />
declare module '*.vue' { 
    import  { DefineComponent } from 'vue'
    const component: DefineComponent
    export default component
}

        配置eslint 跟prettierrc代码规范

一. 代码规范

1.1. 集成editorconfig配置

EditorConfig 有助于为不同 IDE 编辑器上处理同一项目的多个开发人员维护一致的编码风格。

.editorconfig文件的配置,需要安装插件EditorConfig for VS Code

# http://editorconfig.org
root = true
[*] # 表示所有文件适用
charset = utf-8 # 设置文件字符集为 utf-8
indent_style = space # 缩进风格(tab | space)
indent_size = 2 # 缩进大小
end_of_line = lf # 控制换行类型(lf | cr | crlf)
trim_trailing_whitespace = true # 去除行尾的任意空白字符
insert_final_newline = true # 始终在文件末尾插入一个新行
[*.md] # 表示仅 md 文件适用以下规则
max_line_length = off
trim_trailing_whitespace = false

VSCode需要安装一个插件:EditorConfig for VS Code

1.2. 使用prettier工具

        Prettier 是一款强大的代码格式化工具,支持 JavaScript、TypeScript、CSS、SCSS、Less、JSX、Angular、Vue、GraphQL、JSON、Markdown 等语言,基本上前端能用到的文件格式它都可以搞定,是当下最流行的代码格式化工具。

1.安装prettier

npm install prettier -D

2.配置.prettierrc文件:

  • useTabs:使用tab缩进还是空格缩进,选择false;

  • tabWidth:tab是空格的情况下,是几个空格,选择2个;

  • printWidth:当行字符的长度,推荐80,也有人喜欢100或者120;

  • singleQuote:使用单引号还是双引号,选择true,使用单引号;

  • trailingComma:在多行输入的尾逗号是否添加,设置为 none,比如对象类型的最后一个属性后面是否加一个,;

  • semi:语句末尾是否要加分号,默认值true,选择false表示不加;

{
  "useTabs": false,
  "tabWidth": 2,
  "printWidth": 80,
  "singleQuote": true,
  "trailingComma": "none",
  "semi": false
}

3.创建.prettierignore忽略文件

/dist/*
.local
.output.js
/node_modules/**
​
**/*.svg
**/*.sh
​
/public/*

4.VSCode需要安装prettier的插件

        

5.VSCod中的配置(有插件可以不使用命令)

  • settings =>format on save => 勾选上

  • settings => editor default format => 选择 prettier

6.测试prettier是否生效

  • 测试一:在代码中保存代码;

  • 测试二:配置一次性修改的命令;

在package.json中配置一个scripts:

    "prettier": "prettier --write ."

1.3. 使用ESLint检测

1.在前面创建项目的时候,我们就选择了ESLint,所以Vue会默认帮助我们配置需要的ESLint环境。

2.VSCode需要安装ESLint插件:

3.解决eslint和prettier冲突的问题:

安装插件:(vue在创建项目时,如果选择prettier,那么这两个插件会自动安装)

npm install eslint-plugin-prettier eslint-config-prettier -D

添加prettier插件:eslint文件的冲突配置 

  extends: [
    "plugin:vue/vue3-essential",
    "eslint:recommended",
    "@vue/typescript/recommended",
    "@vue/prettier",
    "@vue/prettier/@typescript-eslint",
    'plugin:prettier/recommended' 
  ],

4.VSCode中eslint的配置

  "eslint.lintTask.enable": true,
  "eslint.alwaysShowStatus": true,
  "eslint.validate": [
    "javascript",
    "javascriptreact",
    "typescript",
    "typescriptreact"
  ],
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
  },

5.eslint忽略警告

复制 蓝色代码 在eslint配置文件当中配置rules

          rules: {
                    "@typescript-eslint/no-unused-vars":"off"
                   }

/* eslint-env node */
require("@rushstack/eslint-patch/modern-module-resolution")

module.exports = {
  root: true,
  extends: [
    "plugin:vue/vue3-essential",
    "eslint:recommended",
    "@vue/eslint-config-typescript",
    "@vue/eslint-config-prettier/skip-formatting",
    "plugin:prettier/recommended"
  ],
  parserOptions: {
    ecmaVersion: "latest"
  },
  rules: {
    "@typescript-eslint/no-unused-vars":"off"
   }
}

1.4. git Husky和eslint(后续)

虽然我们已经要求项目使用eslint了,但是不能保证组员提交代码之前都将eslint中的问题解决掉了:

  • 也就是我们希望保证代码仓库中的代码都是符合eslint规范的;

  • 那么我们需要在组员执行 git commit 命令的时候对其进行校验,如果不符合eslint规范,那么自动通过规范进行修复;

那么如何做到这一点呢?可以通过Husky工具:

  • husky是一个git hook工具,可以帮助我们触发git提交的各个阶段:pre-commit、commit-msg、pre-push

如何使用husky呢?

这里我们可以使用自动配置命令:

npx husky-init && npm install

这里会做三件事:

1.安装husky相关的依赖:

2.在项目目录下创建 .husky 文件夹:

3.在package.json中添加一个脚本:

接下来,我们需要去完成一个操作:在进行commit时,执行lint脚本:

这个时候我们执行git commit的时候会自动对代码进行lint校验。

1.5. git commit规范(后续)

1.5.1. 代码提交风格

通常我们的git commit会按照统一的风格来提交,这样可以快速定位每次提交的内容,方便之后对版本进行控制。

但是如果每次手动来编写这些是比较麻烦的事情,我们可以使用一个工具:Commitizen

  • Commitizen 是一个帮助我们编写规范 commit message 的工具;

1.安装Commitizen

npm install commitizen -D

2.安装cz-conventional-changelog,并且初始化cz-conventional-changelog:

npx commitizen init cz-conventional-changelog --save-dev --save-exact

这个命令会帮助我们安装cz-conventional-changelog:

并且在package.json中进行配置:

这个时候我们提交代码需要使用 npx cz

  • 第一步是选择type,本次更新的类型

Type作用
feat新增特性 (feature)
fix修复 Bug(bug fix)
docs修改文档 (documentation)
style代码格式修改(white-space, formatting, missing semi colons, etc)
refactor代码重构(refactor)
perf改善性能(A code change that improves performance)
test测试(when adding missing tests)
build变更项目构建或外部依赖(例如 scopes: webpack、gulp、npm 等)
ci更改持续集成软件的配置文件和 package 中的 scripts 命令,例如 scopes: Travis, Circle 等
chore变更构建流程或辅助工具(比如更改测试环境)
revert代码回退
  • 第二步选择本次修改的范围(作用域)

  • 第三步选择提交的信息

  • 第四步提交详细的描述信息

  • 第五步是否是一次重大的更改

  • 第六步是否影响某个open issue

我们也可以在scripts中构建一个命令来执行 cz:

1.5.2. 代码提交验证

如果我们按照cz来规范了提交风格,但是依然有同事通过 git commit 按照不规范的格式提交应该怎么办呢?

  • 我们可以通过commitlint来限制提交;

1.安装 @commitlint/config-conventional 和 @commitlint/cli

npm i @commitlint/config-conventional @commitlint/cli -D

2.在根目录创建commitlint.config.js文件,配置commitlint

module.exports = {
  extends: ['@commitlint/config-conventional']
}

3.使用husky生成commit-msg文件,验证提交信息:

npx husky add .husky/commit-msg "npx --no-install commitlint --edit $1"

二. 接口文档

接口文档v1版本:

mall_cms

baseURL的值:

http://152.136.185.210:5000
http://152.136.185.210:4000

设置全局token的方法:

const res = pm.response.json();
pm.globals.set("token", res.data.token);

接口文档v2版本:(有部分更新)

mall_cms_v2

三、目录结构

重置css样式

        normalize.css         npm install normalize.css

        reset.css

        在main.ts当中导入

import "normalize.css"
import { createApp } from "vue"
import App from "./App.vue"

createApp(App).mount("#app")

安装less的开发依赖

npm Install less -D

重置reset.less文件


body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td {
    margin: 0;
    padding: 0;
}


a {
    color: #333;
    text-decoration: none;
}

img {
    border: none;
    vertical-align: top;
}
ol, ul, li {
    list-style: none;
}

四、路由配置

        安装路由(如果前面项目没有选择router)

        npm install vue-router

配置路由文件

import { createRouter,createWebHashHistory } from "vue-router";
const router = createRouter({
    history: createWebHashHistory(),
    routes: [

    ]
})
export default router;

引入到main.ts当中去

import router from "./router"
createApp(App).use(router).mount("#app")

配置代码片段(snippet generator

<template>
  <div class="${1:home}">
    <h2>${1:home}</h2>
  </div>
</template>
<script setup lang="ts">


</script>
<style scoped>
.${1:home}{
color: red;
}

</style>

配置页面路由(login,main页面的路由)

import { createRouter, createWebHashHistory } from "vue-router"
const router = createRouter({
  history: createWebHashHistory(),
  routes: [
    {
      path: "/",
      redirect: "/main"
    },
    {
      path: "/login",
      component: () => import("../views/login/login.vue")
    },
    {
      path: "/main",
      component: () => import("../views/main/main.vue")
    }
  ]
})
export default router

五、状态管理工具-pinia

        安装pinia         npm install pinia

1.创建配置文件

import { createPinia } from "pinia"

const pinia = createPinia()

export default pinia

2.在mian.ts当中引入

import pinia from "./store"
app.use(pinia)

3.创建counter文件

import { defineStore } from "pinia"

const userCounterStore = defineStore("counter", {
  state: () => {
    return {
      // 所有这些属性都将自动推断其类型
      counter: 0,
      name: "Eduardo",
      isAdmin: true
    }
  },
  getters: {
    doubleCounter(state) {
      return state.counter * 2
    }
  },
  actions: {
    changeCounterAction(newCounter: number) {
      this.counter = newCounter
    }
  }
})

export default userCounterStore

4.使用store

<template>
  <header>
    <div class="wrapper">
      App
      {{ counterStore.counter }}
      <RouterView />
    </div>
  </header>
</template>
<script setup lang="ts">
import userCounterStore from "./store/counter"
const counterStore = userCounterStore()
</script>

<style scoped></style>

根据环境不同改变环境

console.log(import.meta.env.DEV) //是否开发环境
console.log(import.meta.env.PROD) //是否生产环境
console.log(import.meta.env.SSR) //是否服务端渲染

六、安装element-plus

npm install element-plus --save

全局注册:


import { createApp } from "vue"
import App from "./App.vue"
import ElementPlus from "element-plus"
import "element-plus/dist/index.css"

const app = createApp(App)
app.use(ElementPlus)
app.mount("#app")

 button没有类型

Volar 支持

如果您使用 Volar,请在 tsconfig.json 中通过 compilerOptions.type 指定全局组件类型。

json

// tsconfig.json
{
  "compilerOptions": {
    // ...
    "types": ["element-plus/global"]
  }
}

 在tsconfig.app.json修改配置

{
  "extends": "@vue/tsconfig/tsconfig.dom.json",
  "include": ["env.d.ts", "src/**/*", "src/**/*.vue"],
  "exclude": ["src/**/__tests__/*"],
  "compilerOptions": {
    "composite": true,
    "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
    "baseUrl": ".",
    "paths": {
      "@/*": ["./src/*"]
    },
    "noImplicitAny": false,
    "types": ["element-plus/global"]
  }
}

 按需引入

        npm install -D unplugin-vue-components unplugin-auto-import

按需导入

您需要使用额外的插件来导入要使用的组件。

自动导入推荐

首先你需要安装unplugin-vue-components 和 unplugin-auto-import这两款插件

shell

npm install -D unplugin-vue-components unplugin-auto-import

然后把下列代码插入到你的 Vite 或 Webpack 的配置文件中

Vite环境

ts

// vite.config.ts
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'

export default defineConfig({
  // ...
  plugins: [
    // ...
    AutoImport({
      resolvers: [ElementPlusResolver()],
    }),
    Components({
      resolvers: [ElementPlusResolver()],
    }),
  ],
})

 配置类型tsconfig.app.json

 "include": ["env.d.ts", "src/**/*", "src/**/*.vue", "auto-imports.d.ts", "components.d.ts"],

动态路由

安装   npm install coderwhy -g

coderwhy add3page_setup category -d src/views/main/product/category

 const localRouter: RouteRecordRaw[] = []
      const files: Record<string, any> = import.meta.glob("../../router/main/**/*.ts", {
        eager: true
      })
      for (const key in files) {
        const module = files[key]
        localRouter.push(module.default)
        console.log(module.default)
      }
      // console.log(files)
      //2.根据菜单匹配正确的路由
      for (const menu of this.userMenus) {
        for (const submenu of menu.children) {
          const route = localRouter.find((item) => item.path === submenu.url)
          if (route) router.addRoute("main", route)
        }
      }
      router.push("/main")
    }
  },

  • 14
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3 TS Vite后台管理系统是一个基于Vue3、TypeScript和Vite等技术栈搭建的前端管理框架。该框架主要包含菜单、选项卡和面包屑等模块,通过路由监听实现三个模块之间的联动,并且同时监听浏览器的变化。状态管理方面使用了Pinia进行集中管理。需要注意的是,该示例只包含前端代码,未与后台进行关联实现菜单和用户等权限。如果需要进行权限相关的开发,需要进行二次开发。整体效果如效果图所示。 技术栈方面,主要使用了Vue3、Vue Router、Pinia、Element Plus、Vite等。此外,还使用了一些辅助工具库,如js-cookie等。 项目目录结构如下: - src - assets:资源文件(包括css、img等) - components:公共组件 - pages:存放路由组件 - stores:状态管理 - router:路由配置 - util:工具类 - views:视图组件(存放框架主体组件) - App.vue:根组件 - main.ts:入口文件 - permission.ts:路由跳转权限配置 - setting.ts:配置文件 全局配置文件setting.js统一管理系统的配置,可以进行菜单、选项卡、面包屑等的可配置化。例如可以设置系统名称、是否显示顶部导航、是否显示选项卡、是否显示logo、是否显示菜单等。 该项目的完整代码可以在以下地址下载: [https://gitee.com/yxsmall/vue3-ts-element](https://gitee.com/yxsmall/vue3-ts-element) 总结:以上是对Vue3 TS Vite后台管理系统的简单介绍,如果对该框架感兴趣,可以下载源码进行学习和进一步开发。祝学习进步!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值