创建项目
npm i -g pnpm
pnpm create vite myapp
cd myapp
pnpm install
添加eslint
pnpm i -D eslint
data:image/s3,"s3://crabby-images/d7d22/d7d22cde1953d85d87c8574a0a8e6976f2ef8f6b" alt="在这里插入图片描述"
初始化eslint 配置
pnpm init @eslint/config data:image/s3,"s3://crabby-images/1c738/1c7385e9cf37f5d419b330cbfd48908ba2fc3451" alt="在这里插入图片描述"
添加prettier
pnpm i -D prettier eslint-config-prettier eslint-plugin-prettier data:image/s3,"s3://crabby-images/46e61/46e61fad066263ffa7de130b2b6ab04857aa7e93" alt="在这里插入图片描述"
prettier: 核心模块 eslint-config-prettier: 关闭所有不必要或可能跟prettier 产生冲突的规则 eslint-plugin-prettier : 可以让eslint 使用prettier 规则进行检查
配置eslint 和prettier 兼容
在.eslint.json 的extends 中添加配置:
“plugin:prettier/recommended”
**eslint** 完整配置文件
{
"env": {
"browser": true,
"es2021": true
},
"extends": [
"eslint:recommended",
"plugin:vue/vue3-essential",
"plugin:@typescript-eslint/recommended",
"plugin:prettier/recommended"
],
"parserOptions": {
"ecmaVersion": "latest",
"parser": "@typescript-eslint/parser",
"sourceType": "module"
},
"plugins": [
"vue",
"@typescript-eslint"
],
"rules": {
}
}
配置prettier
手动创建.prettierrc.json 并添加以下内容:
{
"trailingComma": "es5",
"tabWidth": 4,
"semi": true,
"singleQuote": true,
"printWidth": 150
}
webstorm 配置Ctrl+S 时格式化文件
1、 安装prettier 插件 data:image/s3,"s3://crabby-images/4589b/4589b5d14fa371dfb40dfb41081ecd7bcf92865d" alt="在这里插入图片描述"
2、设置启用prettier data:image/s3,"s3://crabby-images/f9891/f98914549622ec69b12a0d214aeb801492cd4bd0" alt="在这里插入图片描述"
3、如果Ctrl+S 还不生效,个性快捷键 data:image/s3,"s3://crabby-images/6e19e/6e19e3ffe6e32b907dd1ffb9e7f2cf322b1cbb20" alt="在这里插入图片描述"
添加husky 和lint-staged
pnpm i -D lint-staged husky
1、执行命令安装 data:image/s3,"s3://crabby-images/35e5d/35e5dd8e8b24afc4d0aa465ae22ccbac865970a1" alt="在这里插入图片描述"
2、在package.json 中添加脚本
npm set-script prepare “husky install” data:image/s3,"s3://crabby-images/cbc63/cbc6300a5f3f7d276c34dd6eca7dea43e17222a6" alt="在这里插入图片描述"
3、初始化husky ,将 git hooks 钩子交由husky 执行 data:image/s3,"s3://crabby-images/1ff10/1ff10fcb814c11ba5b17cd3250ff8dc513374191" alt="在这里插入图片描述"
4、此时会生成.husky 目录 data:image/s3,"s3://crabby-images/c98db/c98db0b46de5fea20dd5fda7b331ce8c4853d6a0" alt="在这里插入图片描述"
5、配置package.json ,增加脚本 data:image/s3,"s3://crabby-images/3b79c/3b79c0ec43cf6313dc5af548e66a7df6c5122af1" alt="在这里插入图片描述"
"scripts": {
"dev": "vite",
"build": "vue-tsc --noEmit && vite build",
"preview": "vite preview",
"eslint": "eslint -ext .js, .jsx, .ts, .tsx, .vue src",
"lint": "lint-staged",
"prettier": "prettier --write",
"prepare": "husky install"
},
"lint-staged": {
"src/**": [
"prettier",
"eslint"
]
},
6、添加勾子pre-commit
npx husky add .husky/pre-commit “npx lint-staged” data:image/s3,"s3://crabby-images/e47af/e47afde3848e6c5fd8c781c281b8d10d91513b51" alt="在这里插入图片描述"
7、生成勾子文件 data:image/s3,"s3://crabby-images/064ab/064ab4b262750318e805f459f269d4b30872185b" alt="在这里插入图片描述"
增加commitlint
- 作用:规范提交信息
- 格式:
git commit -m '类型: 描述性文字'
类型 | 概念 |
---|
build | 编译相关的修改,例如发布版本、对项目构建或者依赖的改动 | ci | 持续集成修改 | docs | 文档修改 | feat | 新特性、新功能 | fix | 修改bug | perf | 优化相关,比如提升性能、体验 | refactor | 代码重构 | revert | 回滚到上一个版本 | style | 代码格式修改, 注意不是 css 修改 | test | 测试用例修改 | chore | 其他修改,比如改变构建流程、或者增加依赖库、工具等 |
1、安装commitlint
pnpm i -D commitlint @commitlint/config-conventional data:image/s3,"s3://crabby-images/9bd0c/9bd0c8a17503677b0601af0708134432536f39f6" alt="在这里插入图片描述"
2、package.json 中配置commitlint
"commotlint": {
"extends": [
"@commitlint/config-conventional"
]
},
增加勾子
npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'
生成 commit-msg data:image/s3,"s3://crabby-images/bca51/bca51f7e55d5d17e87556c0218b59d29a3f1687b" alt="在这里插入图片描述"
|