Vue3项目工程化配置:Eslint + Prettier + husky + commitlint

项目(vue3)中添加husky、eslint、prettier , 自动格式化代码, 保姆级教学。

日常开发中,项目基本上都是由多个人进行开发和维护,每个人的代码书写习惯和风格又不尽相同,commit log也是乱七八糟,为以后的开发和维护增添了很多困难。所以,规范和约束在多人协作下,就显得尤为重要。

首先安装代码检查工具

  • Eslint
npm i eslint -D

Eslint 安装成功后,在项目根目录下执行

npx eslint --init

然后按照终端操作的提示完成一系列设置来创建配置文件。你可以按照下图所示的选择来始化 ESLint


eslint安装.png

这样的设置比较松散,可以在eslintrc.json 中设置规则
比如行尾不写分号

"rules": {
        "semi": ["warn","never"]
    }

然后我们执行

npx eslint src

就可以看到当前项目中哪些不符合规范

上面每次都需要执行npx eslint xxx才能校验,很麻烦。有没有办法在代码保存的时候自动执行Eslint,只需要安装Eslint插件即可:

VSCode中插件市场安装Eslint


image.png

然后设置中添加

"editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
}

更多规则请看这里

在vue3中可能会出现的错误:

  • 错误1
Parsing error: '>' expected.eslint

需要在.eslintrc.json中指定解析器

"parser": "vue-eslint-parser"
  • 错误2
    在vue3.2中不需要申明 emit和props
error ‘defineProps’ is not defined no-undef

解决:

"env": {
    "vue/setup-compiler-macros": true
  },
  • 错误3
    如果有jest,同样需要做相应的配置。
"env": {
    "jest": true
  },

这样,Eslint这块算是完成了,接下来我们添加prettier

npm i prettier eslint-config-prettier eslint-plugin-prettier -D

在根目录创建.prettierrc

{
  "semi": false,
  "tabWidth": 2,
  "trailingComma": "none",
  "singleQuote": true,
  "arrowParens": "avoid"
}

同样vscode中安装prettier


image.png

设置中搜索Formar On Save 并勾选

image.png

设置中添加

"[javascript]": {
    "editor.defaultFormatter": "esbenp.prettier-vscode"
}

在.eslintrc 中,extend中添加 "prettier" 解决 eslint 和 prettier 的冲突

更多规则请看这里

设置完需要重启,否则不会生效

代码提交规范 husky

  • 这里用的husky是7.0.4版本的,老版本可自行百度

简单的举一些常见的githooks例子

Git Hook 执行时机 说明
pre-commit git commit执行前 可以用git commit --no-verify绕过
commit-msg git commit执行前 可以用git commit --no-verify绕过

详细的hooks介绍可以点击这里

首先安装

npm install -D husky

初始化husky

npx husky install .husky

添加一个commit msg钩子

npx husky add .husky/commit-msg "node scripts/verifyCommit.js"

创建verifyCommit.js
添加代码
这段代码逻辑是,找到文件并读取了commit的提交信息,然后使用正则去校验提交信息的格式,如果commit的信息不符合要求,会直接报错并且终止代码的提交。

const msg = require('fs')
  .readFileSync('.git/COMMIT_EDITMSG', 'utf-8')
  .trim()
  
const commitRE = /^(revert: )?(feat|fix|docs|dx|style|refactor|perf|test|workflow|build|ci|chore|types|wip|release)(\(.+\))?: .{1,50}/
const mergeRe = /^(Merge pull request|Merge branch)/
if (!commitRE.test(msg)) {
  if(!mergeRe.test(msg)){
    console.log('git commit信息校验不通过')

    console.error(`git commit的信息格式不对, 需要使用 title(scope): desc的格式
      比如 fix: xxbug
      feat(test): add new 
      具体校验逻辑看 scripts/verifyCommit.js
    `)
    process.exit(1)
  }

}else{
  console.log('git commit信息校验通过')
}

在commit-msg执行的时候我们还可以用代码执行之前的钩子,pre-commit,去执行ESLint代码格式,
这样我们在执行git commit的时候,首先会进行ESLint校验,然后在执行commit的log信息格式检查,全部通过后代码才能提交至Git。

npx husky add .husky/pre-commit "npm run lint"

package.json 中创建

"lint": "eslint --fix --ext .js,vue src/"

commit msg参考
feat: 新功能
fix: 修改 bug
docs: 文档
perf: 性能相关
refactor: 代码重构(就是不影响使用,内部结构的调整)
test: 测试用例
style: 样式修改
workflow: 工作流
build: 项目打包构建相关的配置修改
ci: 持续集成相关
revert: 恢复上一次提交(回滚)
wip: work in progress 工作中 还没完成
chore: 其他修改(不在上述类型中的修改)
release: 发版
deps: 依赖相关的修改

总结
我们通过在项目中添加eslint与prettier和相对应的规则来约束代码,使用husky在代码提交的时候检测代码和约束提交log。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容