vite搭建vue3开发环境
vue3生态pinia vue-router element-plu sass axios pinia
项目代码规范配置Eslint Prettier Editorconfig
Git提交规范Commitizen Husky lint-staged
添加基本依赖
创建vue项目
npm/pnpm create vue@latest
勾选 vue-router pinia Eslint Prettier
or pnpm add vue-router pinia
直接使用 vue-router pinia
假如没有勾选eslint和prettier
pnpm add eslint prettier eslint-plugin-vue eslint-config-prettier eslint-plugin-prettier -D
•**eslint**: ESLint 的核心。
•**prettier**: Prettier 的核心。
•**eslint-plugin-vue**: ESLint 的 Vue.js 插件,专门检查.vue文件。
•**eslint-config-prettier**: 关掉那些跟 Prettier 冲突的 ESLint 规则。
•**eslint-plugin-prettier**: 让 Prettier 变成 ESLint 的一部分,这样代码不符合 Prettier 的格式,ESLint 就会提醒你。
# 2. 配置 ESLint
创建一个.eslintrc.js文件
.eslintrc.js
module.exports ={
env:{
browser:true,//浏览器环境
es2021:true,//支持 ES2021 语法
node:true,// Node.js 环境
},
extends:[
"eslint:recommended",//ESLint 推荐规则
"plugin:vue/vue3-essential",//Vue3 基础规则
"plugin:prettier/recommended",// Prettier 推荐规则(搞定上面那两个包)
],
parserOptions:{
ecmaVersion:"latest",//用最新的ECMAScript 版本
sourceType:"module",//模块类型
},
plugins:["vue"],// 启用 Vue 插件
rules: {
// 你自己的规则
"indent":["error",2,{ SwitchCase:1}],//缩进:2 个空格,switch-case 缩进 1 格
"quotes":["error","double"],// 字符串:双引号
"semi":["error","always"],// 语句结尾:分号
"vue/multi-word-component-names":"off",//关闭组件名称多单词检査(看情况开启)
"no-unused-vars":"off",
//暂时关闭"未使用的变量检查"
"no-empty":["error",{ allowEmptyCatch:true }], // 允许空的 catch 块
//其规则.
},
overrides:[{
files:["src/**/*.vue"], //指定vue文件
rules :{
"vue/multi-word-component-names":"off"//对于vue文件,关闭多单词命名检査
}
}]
};
**配置说明:**
•env: 项目环境配置。
•extends引入配置好的规则
•eslint:recommended: ESLint 的推荐配置。
•plugin:vue/vue3-essential: Vue3 项目基本规则配置。
•plugin:prettier/recommended: 一步到位,启用eslint-plugin-prettier,并将不符合Prettier格式的地方作为 ESLint 错误,禁用冲突规则。
•parserOptions
•ecmaVersion: ECMAScript 版本,"latest"表示最新版。
•sourceType:"module"表示使用 ES 模块。
•plugins:
•"vue"表示启用eslint-plugin-vue.
•**rules**: 这里可以写你自己的规则,或者修改上面引入的规则。
•indent:缩进。
•quotes: 引号相关规则。
•semi:分号相关规则。
•vue/multi-word-component-names: vue 文件命名。
•no-unused-vars:未使用的变量
•no-empty:空代码块**。**
**3. 配置 Prettier**
创建一个.prettierrc.json文件:
{
"useTabs": false,
"tabWidth": 2,
"jsxSingleQuote": false,
"singleQuote": false,
'endOfLine":"lf""semi": true."trailingComma": "es5"
}
**配置解释:**
•useTabs:是否使用tab
•tabWidth: 缩进空格数
•jsxSingleQuote和singleQuote: jsx 和 js 都用双引号。
•endOfLine: 换行
•semi: 语句结尾是否加分号
•trailingComma: 多行的时候,结尾是否加逗号
## 3.vscode安装ESLint 和 Prettier 扩展
{
"editor.defaultFormatter": "esbenp.prettier-vscode", // 默认格式化工具
'editor.formatOnSave":true,//保存时自动格式化
"editor.codeActionsOnSave": {
"source.organizeImports": true, //保存的时候自动优化导入
"source.fixAll": true // 自动修复所有问题
}
}
•"editor.defaultFormatter":把Prettier扩展设置成默认的。
•"editor.formatOnSave":打钩保存自动格式化
•source.organizeImports: 自动优化 import。
•"source.fixAll":自动修复。
**5. 忽略文件(可选)**
创建.eslintignore和.prettierignore文件 内容基本一样
node_modules
dist
public*.md
*.yml
...
项目启动和打包的时候也自动检查代码,可以装一个vite-plugin-eslint插件:
pnpm add vite-plugin-eslint -D
// vite.config.js
import {
defineconfig,
loadEnv
} from "vite";
import eslint from "vite-plugin-eslint";
export default defineconfig(({
mode
}) => {
const env = loadEnv(mode, process.cwd());
return {
plugins: [
eslint({
lintOnStart: true, // 项目启动时检査cache: false//关闭缓存
}),
],
esbuild: {
//根据.env配置,发布的时候去除console 和debugger
drop: env.VITE_DROP_CONSOLE === "true" ? ["console", "debugger"] : [],
},
};
});
pnpm add -D postcss autoprefixer cssnano postcss-preset-env
创建`postcss.config.cjs`文件
module.exports = {
plugins: [
// 使用 require + 选项配置
require('postcss-preset-env')({
stage: 3,
features: {
'nesting-rules': true
}
}),
require('autoprefixer'),
// 生产环境启用 cssnano
process.env.NODE_ENV === 'production'
? require('cssnano')({ preset: 'default' })
: false
].filter(Boolean) // 过滤 false 值
}
创建.browserslistrc
> 0.2%
last 2 versions
not dead
安装sass
pnpm add -D sass
export default defineConfig({
css: {
preprocessorOptions: {
scss: {
additionalData: `@import "@/styles/_variables.scss";`
}
}
}
配置src别名
pnpm i @types/node --save-dev
在vite.config.ts 设置全局scss
import {defineConfig} from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path'
export default defineConfig({
plugins: [vue()],
resolve: {
alias: {
"@": path.resolve("./src") // 相对路径别名配置,使用 @ 代替 src
}
}
gzip 压缩
npm install vite-plugin-compression --save-dev
vite.config.js配置插件配置项
import viteCompression from 'vite-plugin-compression';
export default defineConfig({
plugins: [
viteCompression({
algorithm: 'gzip', // 使用 gzip 压缩
ext: '.gz', // 生成的文件扩展名
threshold: 10240, // 仅压缩大于 10KB 的文件
deleteOriginFile: false, // 是否删除原始文件
compressionOptions: { level: 9 }, // 压缩级别,1-9,越高压缩率越大
filter: /.(js|css|json|html|ico|svg)(?.*)?$/i, // 过滤文件类型
}),
],
});
pnpm add rollup-plugin-terser --dev
drop_console: true表示在压缩过程中会删除所有的 console.*函数调用
import { terser } from "rollup-plugin-terser";
export default defineConfig({
// ...其他配置
build: {
rollupOptions: {
plugins: [
terser({
compress: {
drop_console: true, // 这会删除 console.* 函数的调用
},
}),
],
},
},
});
vite.config.ts 配置说明
root: process.cwd(), // 项目根目录(index.html 文件所在的位置),
base: '/', // 开发或生产环境服务的公共基础路径 配置引入相对路径
mode: 'development', // 模式
plugins: [vue()], // 需要用到的插件数组
publicDir: 'public', // 静态资源服务的文件夹
cacheDir: 'node_modules/.vite', // 存储缓存文件的目录
resolve: {
alias: [ // 文件系统路径别名
{
find: /\/@\//,
replacement: pathResolve('src') + '/'
}
],
dedupe: [], // 强制 Vite 始终将列出的依赖项解析为同一副本
conditions: [], // 解决程序包中 情景导出 时的其他允许条件
mainFields: [], // 解析包入口点尝试的字段列表
extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json'], // 导入时想要忽略的扩展名列表
preserveSymlinks: false, // 启用此选项会使 Vite 通过原始文件路径确定文件身份
},
css: {
modules: {
scopeBehaviour: 'global' | 'local',
// ...
},
postcss: '', // 内联的 PostCSS 配置 如果提供了该内联配置,Vite 将不会搜索其他 PostCSS 配置源
preprocessorOptions: { // css的预处理器选项
scss: {
additionalData: `$injectedColor: orange;`
}
}
},
json: {
namedExports: true, // 是否支持从.json文件中进行按名导入
stringify: false, // 开启此项,导入的 JSON 会被转换为 export default JSON.parse("...") 会禁用按名导入
},
esbuild: { // 最常见的用例是自定义 JSX
jsxFactory: 'h',
jsxFragment: 'Fragment'
},
assetsInclude: ['**/*.gltf'], // 指定额外的 picomatch 模式 作为静态资源处理
logLevel: 'info', // 调整控制台输出的级别 'info' | 'warn' | 'error' | 'silent'
clearScreen: true, // 设为 false 可以避免 Vite 清屏而错过在终端中打印某些关键信息
envDir: '/', // 用于加载 .env 文件的目录
envPrefix: [], // 以 envPrefix 开头的环境变量会通过 import.meta.env 暴露在你的客户端源码中
server: {
host: '127.0.0.1', // 指定服务器应该监听哪个 IP 地址
port: 5000, // 指定开发服务器端口
strictPort: true, // 若端口已被占用则会直接退出
https: false, // 启用 TLS + HTTP/2
open: true, // 启动时自动在浏览器中打开应用程序
proxy: { // 配置自定义代理规则
'/api': {
target: 'http://jsonplaceholder.typicode.com',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}
},
cors: true, // 配置 CORS
force: true, // 强制使依赖预构建
hmr: { // 禁用或配置 HMR 连接
// ...
},
watch: { // 传递给 chokidar 的文件系统监听器选项
// ...
},
middlewareMode: '', // 以中间件模式创建 Vite 服务器
fs: {
strict: true, // 限制为工作区 root 路径以外的文件的访问
allow: [], // 限制哪些文件可以通过 /@fs/ 路径提供服务
deny: ['.env', '.env.*', '*.{pem,crt}'], // 用于限制 Vite 开发服务器提供敏感文件的黑名单
},
origin: 'http://127.0.0.1:8080/', // 用于定义开发调试阶段生成资产的 origin
},
build: {
target: ['modules'], // 设置最终构建的浏览器兼容目标
polyfillModulePreload: true, // 是否自动注入 module preload 的 polyfill
outDir: 'dist', // 指定输出路径
assetsDir: 'assets', // 指定生成静态文件目录
assetsInlineLimit: '4096', // 小于此阈值的导入或引用资源将内联为 base64 编码
cssCodeSplit: true, // 启用 CSS 代码拆分
cssTarget: '', // 允许用户为 CSS 的压缩设置一个不同的浏览器 target 与 build.target 一致
sourcemap: false, // 构建后是否生成 source map 文件
rollupOptions: {}, // 自定义底层的 Rollup 打包配置
lib: {}, // 构建为库
manifest: false, // 当设置为 true,构建后将会生成 manifest.json 文件
ssrManifest: false, // 构建不生成 SSR 的 manifest 文件
ssr: undefined, // 生成面向 SSR 的构建
minify: 'esbuild', // 指定使用哪种混淆器
terserOptions: {}, // 传递给 Terser 的更多 minify 选项
write: true, // 启用将构建后的文件写入磁盘
emptyOutDir: true, // 构建时清空该目录
brotliSize: true, // 启用 brotli 压缩大小报告
chunkSizeWarningLimit: 500, // chunk 大小警告的限制
watch: null, // 设置为 {} 则会启用 rollup 的监听器
},
preview: {
port: 5000, // 指定开发服务器端口
strictPort: true, // 若端口已被占用则会直接退出
https: false, // 启用 TLS + HTTP/2
open: true, // 启动时自动在浏览器中打开应用程序
proxy: { // 配置自定义代理规则
'/api': {
target: 'http://jsonplaceholder.typicode.com',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}
},
cors: true, // 配置 CORS
},
optimizeDeps: {
entries: [], // 指定自定义条目——该值需要遵循 fast-glob 模式
exclude: [], // 在预构建中强制排除的依赖项
include: [], // 可强制预构建链接的包
keepNames: false, // true 可以在函数和类上保留 name 属性
},
ssr: {
external: [], // 列出的是要为 SSR 强制外部化的依赖,
noExternal: '', // 列出的是防止被 SSR 外部化依赖项
target: 'node', // SSR 服务器的构建目标
}
}