commit 1deb1ea0bf5a103d397efbe2d7b7573079786b2a Author: 一瞥 Date: Mon Feb 13 10:18:24 2023 +0800 init diff --git a/.env b/.env new file mode 100644 index 0000000..bb5a5f8 --- /dev/null +++ b/.env @@ -0,0 +1,4 @@ +NODE_ENV=production +VUE_APP_PREVIEW=false +VUE_APP_API_BASE_URL=/api/hto-mp/v1 +PORT=8998 diff --git a/.env.development b/.env.development new file mode 100644 index 0000000..72950d5 --- /dev/null +++ b/.env.development @@ -0,0 +1,2 @@ +VITE_APP_ENV = dev +VITE_APP_TITLE = 我是标题 \ No newline at end of file diff --git a/.env.production b/.env.production new file mode 100644 index 0000000..6ab3136 --- /dev/null +++ b/.env.production @@ -0,0 +1 @@ +VITE_APP_ENV = production \ No newline at end of file diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000..d8ce52d --- /dev/null +++ b/.eslintignore @@ -0,0 +1,16 @@ + +*.sh +node_modules +*.md +*.woff +*.ttf +.vscode +.idea +dist +/public +/docs +.husky +.local +/bin +Dockerfile +.npmrc \ No newline at end of file diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 0000000..5fcac9e --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,78 @@ +// @ts-check +const { defineConfig } = require('eslint-define-config'); +module.exports = defineConfig({ + root: true, + env: { + browser: true, + node: true, + es6: true, + }, + parser: 'vue-eslint-parser', + parserOptions: { + parser: '@typescript-eslint/parser', + ecmaVersion: 2020, + sourceType: 'module', + jsxPragma: 'React', + ecmaFeatures: { + jsx: true, + }, + }, + extends: [ + 'plugin:vue/vue3-recommended', + 'plugin:@typescript-eslint/recommended', + 'prettier', + 'plugin:prettier/recommended', + 'plugin:jest/recommended', + ], + rules: { + 'vue/script-setup-uses-vars': 'error', + '@typescript-eslint/ban-ts-ignore': 'off', + '@typescript-eslint/explicit-function-return-type': 'off', + '@typescript-eslint/no-explicit-any': 'off', + '@typescript-eslint/no-var-requires': 'off', + '@typescript-eslint/no-empty-function': 'off', + 'vue/custom-event-name-casing': 'off', + 'no-use-before-define': 'off', + '@typescript-eslint/no-use-before-define': 'off', + '@typescript-eslint/ban-ts-comment': 'off', + '@typescript-eslint/ban-types': 'off', + '@typescript-eslint/no-non-null-assertion': 'off', + '@typescript-eslint/explicit-module-boundary-types': 'off', + '@typescript-eslint/no-unused-vars': [ + 'error', + { + argsIgnorePattern: '^_', + varsIgnorePattern: '^_', + }, + ], + 'no-unused-vars': [ + 'error', + { + argsIgnorePattern: '^_', + varsIgnorePattern: '^_', + }, + ], + 'space-before-function-paren': 'off', + + 'vue/attributes-order': 'off', + 'vue/one-component-per-file': 'off', + 'vue/html-closing-bracket-newline': 'off', + 'vue/max-attributes-per-line': 'off', + 'vue/multiline-html-element-content-newline': 'off', + 'vue/singleline-html-element-content-newline': 'off', + 'vue/attribute-hyphenation': 'off', + 'vue/require-default-prop': 'off', + 'vue/html-self-closing': [ + 'error', + { + html: { + void: 'always', + normal: 'never', + component: 'always', + }, + svg: 'always', + math: 'always', + }, + ], + }, +}); diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..cfb0ddf --- /dev/null +++ b/.gitignore @@ -0,0 +1,31 @@ +node_modules +.DS_Store +dist +.cache + +package-lock.json +yarn.lock + +.local +# local env files +.env.local +.env.*.local +.eslintcache + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + +# Editor directories and files +.idea +# .vscode +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? + +**/src/auto-imports.d.ts +**/src/components.d.ts diff --git a/.husky/commit-msg b/.husky/commit-msg new file mode 100644 index 0000000..567ff71 --- /dev/null +++ b/.husky/commit-msg @@ -0,0 +1,6 @@ +#!/bin/sh + +# shellcheck source=./_/husky.sh +. "$(dirname "$0")/_/husky.sh" + +npx --no-install commitlint --edit "$1" diff --git a/.husky/common.sh b/.husky/common.sh new file mode 100644 index 0000000..9d5129b --- /dev/null +++ b/.husky/common.sh @@ -0,0 +1,9 @@ +#!/bin/sh +command_exists () { + command -v "$1" >/dev/null 2>&1 +} + +# Workaround for Windows 10, Git Bash and Yarn +if command_exists winpty && test -t 1; then + exec < /dev/tty +fi diff --git a/.husky/lintstagedrc.js b/.husky/lintstagedrc.js new file mode 100644 index 0000000..46e5a84 --- /dev/null +++ b/.husky/lintstagedrc.js @@ -0,0 +1,7 @@ +module.exports = { + '*.{js,jsx,ts,tsx}': ['eslint --fix', 'prettier --write'], + '{!(package)*.json,*.code-snippets,.!(browserslist)*rc}': ['prettier --write--parser json'], + 'package.json': ['prettier --write'], + '*.vue': ['eslint --fix', 'prettier --write'], + '*.{scss,less,styl,html}': ['prettier --write'], +}; diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100644 index 0000000..35f9242 --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1,8 @@ +#!/bin/sh +. "$(dirname "$0")/_/husky.sh" +. "$(dirname "$0")/common.sh" + +[ -n "$CI" ] && exit 0 + +# Format and submit code according to lintstagedrc.js configuration +npm run lint:lint-staged diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..2aa30de --- /dev/null +++ b/.npmrc @@ -0,0 +1,8 @@ +# 提升一些依赖包至 node_modules +# 解决部分包模块not found的问题 +# 用于配合 pnpm +#shamefully-hoist = true + +# node-sass 下载问题 +registry = "https://registry.npm.taobao.org" +sass_binary_site="https://npm.taobao.org/mirrors/node-sass/" diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000..58a03a8 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,18 @@ +**/*.svg +**/*.ico +package.json +/dist +.DS_Store +.eslintignore +*.png +*.toml +.editorconfig +.gitignore +.prettierignore +LICENSE +.eslintcache +*.lock +yarn-error.log +/public +**/node_modules/** +.npmrc \ No newline at end of file diff --git a/.vscode/extensions.json b/.vscode/extensions.json new file mode 100644 index 0000000..3dc5b08 --- /dev/null +++ b/.vscode/extensions.json @@ -0,0 +1,3 @@ +{ + "recommendations": ["johnsoncodehk.volar"] +} diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..63864b0 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,35 @@ +# [1.0.0](https://github.com/js-banana/vite-vue3-ts/compare/v1.1.0...v1.0.0) (2022-08-09) + +# [1.0.0](https://github.com/js-banana/vite-vue3-ts/compare/v1.1.0...v1.0.0) (2022-08-09) + +# [1.0.0](https://github.com/js-banana/vite-vue3-ts/compare/v1.1.0...v1.0.0) (2022-08-09) + +# [1.0.0](https://github.com/js-banana/vite-vue3-ts/compare/v1.1.0...v1.0.0) (2022-08-09) + +# [1.0.0](https://github.com/js-banana/vite-vue3-ts/compare/v1.1.0...v1.0.0) (2022-08-09) + +### Bug Fixes + +- nav ([a66af47](https://github.com/js-banana/vite-vue3-ts/commit/a66af4704c00fac48fcd6d30f1fa05f3c883aad9)) +- **router:** 域名二级目录的路由配置优化 ([9b8c887](https://github.com/js-banana/vite-vue3-ts/commit/9b8c8876d61ebbdda7b16cc10aa19083517eceb2)) +- **SideMenu:** 修复菜单文本与图标居中 ([60bafa0](https://github.com/js-banana/vite-vue3-ts/commit/60bafa0711b2f44df76f2979399ac95998576d67)) + +### Features + +- **.env:** 增加环境变量配置文件 ([403029c](https://github.com/js-banana/vite-vue3-ts/commit/403029cb0ad703f4ea464a81876987a64b570f37)) +- 调整权限逻辑,补充 v-role 指令 ([9a9598b](https://github.com/js-banana/vite-vue3-ts/commit/9a9598b2bb85a5c8baf5a08c56efd0e308514b96)) +- 添加路由动效,抽离 Breadcrumb 组件 ([d32087c](https://github.com/js-banana/vite-vue3-ts/commit/d32087c9f9490f6245589fce42342b19e3068b5e)) +- 增加 Table 使用 demo,完善文档说明,优化 Table API,保持与官方 antv 一致 ([159e0da](https://github.com/js-banana/vite-vue3-ts/commit/159e0da34c2897d4d2a3433ac793cfa3c4521cf2)) +- vite2.x => vite3.x 工具链生态相关升级更新 ([820c02e](https://github.com/js-banana/vite-vue3-ts/commit/820c02e0f1eec256bf4fc9884cb25f2631fa803e)) + +### Performance Improvements + +- 路由模式由 hash 调整为 history ([e37f2f6](https://github.com/js-banana/vite-vue3-ts/commit/e37f2f60291241ec4ab30134afd46b0dd83815a8)) + +## [0.0.1](https://github.com/js-banana/vite-vue3-ts/compare/219fe493bd2623c0abfab0e4ef48a2a12838ccdf...v0.0.1) (2021-12-13) + +### Features + +- **app:** 生产环境 mock、功能组件、路由完善 ([74b1983](https://github.com/js-banana/vite-vue3-ts/commit/74b1983c7a946b2fb1a95afcd3870a13db96fa9b)) +- **mock:** mock 数据编写 ([219fe49](https://github.com/js-banana/vite-vue3-ts/commit/219fe493bd2623c0abfab0e4ef48a2a12838ccdf)) +- update app and docs ([b61d9ce](https://github.com/js-banana/vite-vue3-ts/commit/b61d9cea26c522850eca74cb0833d5efd90c52c1)) diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..1302d4a --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2020-present, JS-banana + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..2b787f4 --- /dev/null +++ b/README.md @@ -0,0 +1,245 @@ +# vite-vue3-ts + +[![ci](https://github.com/JS-banana/vite-vue3-ts/actions/workflows/deploy.yml/badge.svg)](https://github.com/JS-banana/vite-vue3-ts/actions/workflows/deploy.yml) + +## 介绍 + +一个使用 `vite` + `vue3` + `pinia` + `ant-design-vue` + `typescript` 完整技术路线开发的项目,秒级开发更新启动、新的`vue3 composition api` 结合 `setup`纵享丝滑般的开发体验、全新的 `pinia`状态管理器和优秀的设计体验(`1k`的size)、`antd`无障碍过渡使用UI组件库 `ant-design-vue`、安全高效的 `typescript`类型支持、代码规范验证、多级别的权限管理~ + +相关文章: + +本项目相关改动及更新见【[更新记录](#更新记录)↓↓↓】 + +## 特性 + +- ✨脚手架工具:高效、快速的 **Vite** +- 🔥前端框架:眼下最时髦的 **Vue3** +- 🍍状态管理器:`vue3`新秀 **Pinia**,犹如 `react zustand`般的体验,友好的api和异步处理 +- 🏆开发语言:政治正确 **TypeScript** +- 🎉UI组件:`antd`开发者无障碍过渡使用 **ant-design-vue**,熟悉的配方熟悉的味道 +- 🎨css样式:**less** 、`postcss` +- 📖代码规范:**Eslint**、**Prettier**、**Commitlint** +- 🔒权限管理:页面级、菜单级、按钮级、接口级 +- ✊依赖按需加载:**unplugin-auto-import**,可自动导入使用到的`vue`、`vue-router`等依赖 +- 💪组件按需导入:**unplugin-vue-components**,无论是第三方UI组件还是自定义组件都可实现自动按需导入以及`TS`语法提示 + +## 项目目录 + +```js +├── .husky // husky git hooks配置目录 + ├── _ // husky 脚本生成的目录文件 + ├── commit-msg // commit-msg钩子,用于验证 message格式 + ├── pre-commit // pre-commit钩子,主要是和eslint配合 +├── config // 全局配置文件 + ├── vite // vite 相关配置 + ├── constant.ts // 项目配置 + ├── themeConfig.ts // 主题配置 +├── dist // 默认的 build 输出目录 +├── mock // 前端数据mock +├── public // vite项目下的静态目录 +└── src // 源码目录 + ├── api // 接口相关 + ├── assets // 公共的文件(如image、css、font等) + ├── components // 项目组件 + ├── directives // 自定义 指令 + ├── enums // 自定义 常量(枚举写法) + ├── hooks // 自定义 hooks + ├── layout // 全局布局 + ├── router // 路由 + ├── store // 状态管理器 + ├── utils // 工具库 + ├── views // 页面模块目录 + ├── login // login页面模块 + ├── ... + ├── App.vue // vue顶层文件 + ├── auto-imports.d.ts // unplugin-auto-import 插件生成 + ├── components.d.d.ts // unplugin-vue-components 插件生成 + ├── main.ts // 项目入口文件 + ├── shimes-vue.d.ts // vite默认ts类型文件 + ├── types // 项目type类型定义文件夹 +├── .editorconfig // IDE格式规范 +├── .env // 环境变量 +├── .eslintignore // eslint忽略 +├── .eslintrc // eslint配置文件 +├── .gitignore // git忽略 +├── .npmrc // npm配置文件 +├── .prettierignore // prettierc忽略 +├── .prettierrc // prettierc配置文件 +├── index.html // 入口文件 +├── LICENSE.md // LICENSE +├── package.json // package +├── pnpm-lock.yaml // pnpm-lock +├── postcss.config.js // postcss +├── README.md // README +├── tsconfig.json // typescript配置文件 +└── vite.config.ts // vite +``` + +## 使用说明 + +> 简要说明: +> +> 随着vite3.x的发布,本项目针对该依赖的相关生态做了升级,详情见分支 [feat-vite3.x](https://github.com/JS-banana/vite-vue3-ts/tree/feat-vite3.x) +> +> 需要指出的是vite3.x要求node14.18及以上,详情见 [从 v2 迁移](https://cn.vitejs.dev/guide/migration.html) + +1. 克隆本项目 + + ```sh + git clone https://github.com/JS-banana/vite-vue3-ts.git + ``` + +2. 安装依赖 + + ```sh + # 推荐使用 pnpm + pnpm install + # 没有安装的直接安装 + npm install -g pnpm + ``` + +3. 启动项目 + + ```sh + pnpm serve + # or + pnpm dev + ``` + +4. 部署 + + ```sh + # 检查TS类型然后构建打包 + pnpm build:check + # 跳过检查直接构建打包 + pnpm build + # 预览 + pnpm preview + ``` + +### 数据模拟 + +为了实现更多元化和真实数据展示,使用了Mock+fakerjs进行数据模拟,fakerjs的功能极其强大,几乎可以定制任何类型数据,本项目里做了部分演示,源码见`mock/table.ts` + +### ant-design-vue 2.x升级到3.x的说明 + +Table组件: + +在2.x版本的时候,Table组件主要通过 `columns`属性,配置字段 `slots: { customRender: 'action' }`进行自定义插槽,做到制定内容的内容,基于此,本项目Table组件封装的内部实现为`