命令行工具输入以下命令,生成模板项目
npm init vue@latest
说明
✔ Project name: … <项目名称>
✔ Add TypeScript? … No / Yes ---------------------------------------- #安装 TypeScript
✔ Add JSX Support? … No / Yes ---------------------------------------- #安装对 JSX 语法的支持
✔ Add Vue Router for Single Page Application development? … No / Yes - #安装 Vue Router 路由管理
✔ Add Pinia for state management? … No / Yes ------------------------- #安装 Pinia 状态管理
✔ Add Vitest for Unit testing? … No / Yes ---------------------------- #安装 Vitest 单元测试
✔ Add Cypress for both Unit and End-to-End testing? … No / Yes ------- #安装 Cypress 端到端测试
✔ Add ESLint for code quality? … No / Yes ---------------------------- #安装 ESLint 代码校验
✔ Add Prettier for code formatting? … No / Yes ----------------------- #安装 Prettier 统一代码规范
node_modules --------------------------------- 第三方依赖文件
public --------------------------------------- 公共文件夹(如icon图标)
src ------------------------------------------ 项目页面目录
.env ----------------------------------------- 环境变量配置
.env.development ----------------------------- 开发环境下的配置文件
.env.production ------------------------------ 生产环境下的配置文件
.eslintignore -------------------------------- 配置 Eslint 忽略检查的文件目录、文件等
.eslintrc.js --------------------------------- 配置 Eslint 代码校验规则
.gitignore ----------------------------------- 配置 Git 忽略目录或文件
.prettierrc.js ------------------------------- 配置代码规范,统一代码风格
index.html ----------------------------------- 项目挂载的 html 页面
LICENSE -------------------------------------- 开源声明
package-lock.json ---------------------------- 主要用于记录了上一次安装的依赖的版本号(为升级后不兼容,提供回退参考)
package.json --------------------------------- 该项目包必要的说明文件
plugins.d.ts --------------------------------- 插件类型声明文件
README.md ------------------------------------ 该项目说明文件
vue.d.ts ------------------------------------- .vue文件类型声明文件
source.d.ts ---------------------------------- 资源类型声明文件
tsconfig.json -------------------------------- Ts编译器配置文件
vite.config.ts ------------------------------- vite配置文件
package.json
文件{
"name": "",// ----------------------------------------- 项目名称
"version": "1.0.0",// --------------------------------- 项目的版本
"description": "快速了解该项目的功能及作用", // --------- 项目的描述
"scripts": {// ---------------------------------------- 定义命令别名,当命令很长时可以使用别名替换
"dev": "vite", // 默认 command 的值为 serve, mode 为 development
"build": "vue-tsc --noEmit && vite build", // 默认 command 的值为 build, mode 为 production
"preview": "vite preview"
},
"keywords": [],// -------------------------------------- 关键字,它允许我们使用关键字去描述当前的项目
"author": "",//----------------------------------------- 项目的作者
"license": "MIT",//------------------------------------- 项目遵循的协议,默认是ISC也就是开放源代码的协议
"dependencies": {},//----------------------------------- 项目所需要依赖的第三方模块(包)
"devDependencies": {},//-------------------------------- 仅开发时所需要依赖的第三方模块(包)
"repository": {},// ------------------------------------ 项目仓库地址
"browserslist": []// ----------------------------------- 适用的浏览器
// ...
}
vite.config.ts
文件Vite 会自动解析 项目根目录下名为 vite.config.js 的文件,请根据实际需要进行配置
import vue from '@vitejs/plugin-vue';
import { resolve } from 'path';
import { defineConfig, loadEnv, ConfigEnv } from 'vite';
const pathResolve = (dir: string): any => {
return resolve(__dirname, '.', dir);
};
const alias: Record = {
'/@': pathResolve('./src/'),
};
/**
* @command 在 Vite 的 API 中,在开发环境下 command 的值为 serve(在 CLI 中, vite dev 和 vite serve 是 vite 的别名),而在生产环境下为 build(vite build)
* @mode 根据当前工作目录中的 `mode` 加载 .env 文件
* @ssrBuild 用于服务端渲染时
*/
export default defineConfig(({ command, mode, ssrBuild }) => {
// 使用 Vite 导出的 loadEnv 函数来加载指定的 .env 文件,设置第三个参数为 '' 来加载所有环境变量,而不管是否有 `VITE_` 前缀
const env = loadEnv(mode, process.cwd(), '')
return {
// vite 共享配置
root: process.cwd(), // ----------------- 项目根目录(index.html 文件所在的位置)
base: 'workbench', // ----------------- 开发或生产环境服务的公共基础路径
mode: "development", // ----------------- 默认: 'development' 用于开发,'production' 用于构建
define: { __APP_ENV__: env.APP_ENV }, // --- 定义全局常量替换方式
plugins: [vue()], // ----------------- 需要用到的插件数组
resolve: { alias }, // ----------------- 定义文件路径别名,当使用文件系统路径的别名时,请始终使用绝对路径,否则无法解析
css: { // ----------------- css 配置
postcss: { // ----------------- 内联的 PostCSS 配置
plugins: [{
postcssPlugin: 'internal:charset-removal',
AtRule: { charset: (atRule) => { if (atRule.name === 'charset') { atRule.remove() }}},
}],
},
},
// 开发时服务器配置选项 执行 npm run dev 时
server: {
host: 'localhost', // 指定服务器应该监听哪个 IP 地址
port: 3000, // 端口
open: false, // 在开发服务器启动时自动在浏览器中打开应用程序
// 为开发服务器配置自定义代理规则,如前端接口调用: fetch('/api/dev')
// 此时会通过上面的代理规则,将源地址代理到目标地址,从而访问目标地址的接口 https://googxh.xyz/api/dev
proxy: {
'/dev': {
target: 'https://googxh.xyz',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/dev/, ''),
},
},
},
// 构建打包时配置选项 执行 npm run build 时
build: {
outDir: 'bundle',// 指定输出路径(相对于 项目根目录)
sourcemap: false, // 构建后是否生成 source map 文件
chunkSizeWarningLimit: 1500, // 规定触发警告的 chunk(文件块) 大小
rollupOptions: { // 自定义底层的 Rollup 打包配置
output: {
entryFileNames: `assets/[name].${new Date().getTime()}.js`,
chunkFileNames: `assets/[name].${new Date().getTime()}.js`,
assetFileNames: `assets/[name].${new Date().getTime()}.[ext]`,
compact: true,
manualChunks: {
vue: ['vue', 'vue-router', 'pinia'],
echarts: ['echarts'],
},
},
},
//生产环境自动删除console
terserOptions: {
compress: {
drop_console: true, // 自动去除console
drop_debugger: true, // 清除 debugger 语句
},
ie8: true,
output: { comments: true }, // 删除注释
},
},
}
})
tsconfig.json
文件TypeScript 编译器配置文件,请根据实际需要进行配置
{
"compilerOptions": {
"incremental": true, // ----------------- TS编译器在第一次编译之后会生成一个存储编译信息的文件,第二次编译会在第一次的基础上进行增量编译,可以提高编译的速度
"tsBuildInfoFile": "./buildFile", // ---- 增量编译文件的存储位置
"target": "esnext" /* 目标语言的版本: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */,
"module": "esnext" /* 生成代码的模板标准: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */,
"lib": ["esnext", "dom", "dom.iterable", "scripthost"] /* Specify library files to be included in the compilation. */,
"allowJs": true, /* 允许编译器编译 JS,JSX 文件 */
"checkJs": true, /* 允许在 JS 文件中报错,通常与 allowJS 一起使用 */
"jsx": "preserve" /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */,
"declaration": true, /* 生成声明文件,开启后会自动生成声明文件 */
"declarationDir": "./file", /* 指定生成声明文件存放目录 */
"declarationMap": true, /* 为声明文件生成 sourceMap '.d.ts' file. */
"sourceMap": true, /* 生成目标文件的 sourceMap 文件 */
"outFile": "./", /* 将多个相互依赖的文件生成一个文件,可以用在AMD模块中,即开启时应设置"module": "AMD" */
"outDir": "./", /* 指定输出目录 */
"rootDir": "./", /* 指定输出文件目录(用于输出),用于控制输出目录结构 */
"composite": true, /* Enable project compilation */
"removeComments": true, /* 删除注释 */
"noEmit": true, /* 不输出文件,即编译后不会生成任何js文件 */
"noEmitOnError": true, /* 发送错误时不输出任何文件 */
"noEmitHelpers": true, /* 不生成helper函数,减小体积,需要额外安装,常配合importHelpers一起使用 */
"importHelpers": true /* 通过 tslib 引入helper 函数,文件必须是模块 */,
"downlevelIteration": true /* 降级遍历器实现,如果目标源是 Es3/Es5 ,那么遍历器会有降级的实现 */,
"isolatedModules": true /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */,
"strict": true /* 开启所有严格的类型检查*/,
"noImplicitAny": true, /* 不允许隐式的 any 类型 */
"strictNullChecks": true, /* 不允许把 null、undefined 赋值给其他类型的变量 */
"strictFunctionTypes": true, /* 不允许函数参数双向协变 */
"strictBindCallApply": true, /* 严格的 bind/call/apply 检查 */
"strictPropertyInitialization": true, /* 类的实例属性必须初始化 */
"noImplicitThis": true, /* 不允许 this 有隐式的 any 类型 */
"alwaysStrict": true, /* 在代码中注入'use strict' */
"noUnusedLocals": true, /* 检查只声明、未使用的局部变量(只提示不报错) */
"noUnusedParameters": true, /* 检查未使用的函数参数(只提示不报错) */
"noImplicitReturns": true, /* 每个分支都会有返回值 */
"noFallthroughCasesInSwitch": true, /* 防止switch语句贯穿(即如果没有break语句后面不会执行) */
"noUncheckedIndexedAccess": true, /* 没有在接口里声明的对象的属性,会添加一个 undefined 类型 */
"moduleResolution": "node" /* 模块解析策略,ts 默认用 node 的解析策略,即相对的方式导入, 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */,
"baseUrl": "." /* 解析非相对模块的基地址,默认是当前目录 */,
"paths": { "/@/*": ["src/*"] } /* 路径映射,相对于 baseUrl */,
"rootDirs": [], /* 将多个目录放在一个虚拟目录下,用于运行时,即编译后引入文件的位置可能发生变化,这也设置可以虚拟src和out在同一个目录下,不用再去改变路径也不会报错 */
"typeRoots": [], /* 声明文件目录,默认时 node_modules/@types */
"types": ["vite/client"] /* 加载的声明文件包 */,
"allowSyntheticDefaultImports": true /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */,
"esModuleInterop": true /* 允许 export 导出,由 import from 导入. */,
"preserveSymlinks": true, /* Do not resolve the real path of symlinks. */
"allowUmdGlobalAccess": true, /* 允许在模块中全局变量的方式访问umd模块. */
"sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */
"mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */
"inlineSourceMap": true, /* 生成目标文件的inline SourceMap,inline SourceMap会包含在生成的js文件中. */
"inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */
"experimentalDecorators": true /* Enables experimental support for ES7 decorators. */,
"emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */
"skipLibCheck": true /* Skip type checking of declaration files. */,
"forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */
}
}
.eslintrc.js
文件请根据实际需要进行配置
module.exports = {
root: true,
env: {
browser: true,
es2021: true,
node: true,
},
parser: 'vue-eslint-parser',
parserOptions: {
ecmaVersion: 12,
parser: '@typescript-eslint/parser',
sourceType: 'module',
},
extends: ['plugin:vue/vue3-essential', 'plugin:vue/essential', 'eslint:recommended'],
plugins: ['vue', '@typescript-eslint'],
rules: {
'@type-eslint/ban-ts-ignore': 'off',
'@type-eslint/explicit-function-return-type': 'off',
'@type-eslint/no-explicit-any': 'off',
'@type-eslint/no-var-requires': 'off',
'@type-eslint/no-empty-function': 'off',
'@type-eslint/no-use-before-define': 'off',
'@type-eslint/ban-ts-comment': 'off',
'@type-eslint/ban-types': 'off',
'@type-eslint/no-non-null-assertion': 'off',
'@type-eslint/explicit-module-boundary-types': 'off',
'vue/custom-event-name-casing': '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/html-self-closing': 'off',
'vue/no-multiple-template-root': 'off',
'vue/require-default-prop': 'off',
'vue/no-v-model-argument': 'off',
'vue/no-arrow-functions-in-watch': 'off',
'vue/no-template-key': 'off',
'vue/no-v-html': 'off',
'vue/comment-directive': 'off',
'vue/no-parsing-error': 'off',
'vue/no-deprecated-v-on-native-modifier': 'off',
'vue/multi-word-component-names': 'off',
'no-useless-escape': 'off',
'no-sparse-arrays': 'off',
'no-prototype-builtins': 'off',
'no-constant-condition': 'off',
'no-use-before-define': 'off',
'no-restricted-globals': 'off',
'no-restricted-syntax': 'off',
'generator-star-spacing': 'off',
'no-unreachable': 'off',
'no-multiple-template-root': 'off',
'no-unused-vars': 'error',
'no-v-model-argument': 'off',
'no-case-declarations': 'off',
// 'no-console': 'error',
},
};
.prettierrc.js
文件请根据实际需要进行配置
module.exports = {
printWidth: 150, // 一行最多多少个字符
tabWidth: 2, // 指定每个缩进级别的空格数
useTabs: true, // 使用制表符而不是空格缩进行
semi: true, // 在语句末尾打印分号
singleQuote: true, // 使用单引号而不是双引号
quoteProps: 'as-needed', // 更改引用对象属性的时间 可选值""
jsxSingleQuote: false, // 在JSX中使用单引号而不是双引号
trailingComma: 'es5', // 多行时尽可能打印尾随逗号。(例如,单行数组永远不会出现逗号结尾。) 可选值"",默认none
bracketSpacing: true, // 在对象文字中的括号之间打印空格
jsxBracketSameLine: false, // jsx 标签的反尖括号需要换行
arrowParens: 'always', // 在单独的箭头函数参数周围包括括号 always:(x) => x \ avoid:x => x
rangeStart: 0, // 这两个选项可用于格式化以给定字符偏移量(分别包括和不包括)开始和结束的代码
rangeEnd: Infinity,
requirePragma: false, // 指定要使用的解析器,不需要写文件开头的 @prettier
insertPragma: false, // 不需要自动在文件开头插入 @prettier
proseWrap: 'preserve', // 使用默认的折行标准 always\never\preserve
htmlWhitespaceSensitivity: 'css', // 指定HTML文件的全局空格敏感度 css\strict\ignore
vueIndentScriptAndStyle: fale, // Vue文件脚本和样式标签缩进
endOfLine: 'lf', // 换行符使用 lf 结尾是 可选值""
};