使用husky + lint-staged助力团队编码规范

Pre-commit:如何使用 husky、lint-staged和prettier优化你的项目

在软件开发过程中,代码风格检查(Code Linting)是保障代码规范和一致性的有效手段。过去,Lint 的工作一般在 Code Review 或者 CI 的时候进行,但这样会导致问题的反馈链,浪费不必要的时间。因此,我们需要利用 Git 的 Pre Commit 钩子,将 Lint 过程放到开发者提交代码之前。

简介

简单介绍一下这三个工具:

  • prettier 用来优化代码格式,比如缩进、空格、分号等等
  • husky 可以用于实现各种 Git Hook。这里主要用到 pre-commit这个 hook,在执行 commit 之前,运行一些自定义操作
  • lint-staged 用于对 Git 暂存区中的文件执行代码检测

安装

首先,我们使用下面的命令把 husky 和 lint-staged 安装到package.jsondevDependencies中:

npm install husky lint-staged prettier --save-dev
或者
yarn add husky lint-staged prettier --dev

配置package.json

将下面的代码追加到 package.json文件中:

{
  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  },
  "lint-staged": {
    "*.{js,vue}": [
      "prettier --write",
      "vue-cli-service lint",
      "git add"
    ]
  }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

上面示例中lint-staged下的选项是vue项目中常用的配置,你可以根据你项目的技术栈配置相应的代码检查。

  • prettier --write会自动美化你的代码格式
  • vue-cli-service lint是vue项目中语法检查
  • git add将更改后到文件添加到暂存区

.prettierrc文件

新建一个.prettierrc文件,将以下内容复制进去:

{
  "trailingComma": "es5", // 尾随逗号
  "tabWidth": 4, // 缩进
  "semi": true, // 句尾分号
  "singleQuote": true, // 单引号
  "end-of-line": "lf" // 换行符
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

这样,当在终端输入 git commit命令提交代码的时候,Lint 程序便会自动检查本次提交所修改的文件是否符合本项目的代码规范。如果代码不符合规范,便会拒绝提交代码。

如果想要跳过 Lint 程序,可以使用 git commit -no-verify 进行提交。

参看文献

husky: https://www.npmjs.com/package/husky
lint-staged: https://www.npmjs.com/package/lint-staged
prettier: https://www.npmjs.com/package/prettier

扫码关注

 
posted @ 2021-04-26 11:36  一纸荒唐  阅读(237)  评论(0编辑  收藏  举报