npm script 应用在 git hooks 中

栏目: 编程工具 · 发布时间: 5年前

内容简介:一个项目往往不只一个人开发,多人合作自然需要版本控制来合理管理代码,比如 git、svn 等。个人喜欢 git,以及直男社区 github。git 除了能管理代码版本,还可以在 npm script 里运用,不然我也不会在这啰嗦那么多做铺垫了。git 在 npm script 的运用主要体现在注:有些懒可以偷,有些不可以。有些懒,虽一时方便了自己,但长远来看,不仅是坑了自己,更是坑了整个团队。1.安装依赖包 husky 后,可查看

一个项目往往不只一个人开发,多人合作自然需要版本控制来合理管理代码,比如 git、svn 等。个人喜欢 git,以及直男社区 github。git 除了能管理代码版本,还可以在 npm script 里运用,不然我也不会在这啰嗦那么多做铺垫了。git 在 npm script 的运用主要体现在 prepost 的钩子上,也就是大家熟知的 git hooks,能帮助我们在代码提交(commit)和获取时(push)做一些事情。

说说场景

  • 本地仓库配置 pre-commitpre-push ,是给 要提交的代码 做检查;
  • 远程仓库配置 pre-receive ,是给 拉取下来的代码 做检查,以确保符合本地代码规范,假如没有这步,本地开发者偷懒使用 --no-verify (或 -n )就可以规避本地代码检查;

注:有些懒可以偷,有些不可以。有些懒,虽一时方便了自己,但长远来看,不仅是坑了自己,更是坑了整个团队。

全面检查

安装依赖包

npm install husky -D
// 或
yarn add husky -D
复制代码

编写

{   
    "scripts": {
        "lint:js": "# 检查 js \n  eslint ./src/**/*.js",
        "test": "# 单元测试 \n cross-env NODE_ENV=test mocha tests/"
    },
    "husky": {
        "hooks": {
            "pre-commit": "npm run lint:js",
            "pre-push": "npm run test"
        }
    },
}
复制代码

剖析

1.安装依赖包 husky 后,可查看 .git/hooks 目录,都是 husky 的钩子

npm script 应用在 git hooks 中

执行

1.代码开发完毕,准备提交到本地仓库

git commit -am "git hooks 的使用"
复制代码

此时会调用 pre-commit ,发现错误:

npm script 应用在 git hooks 中

2.解决了有错误的 request.js 问题,提交到远程分支上,又发现单元测试环节出现了问题:

npm script 应用在 git hooks 中

3.解决单元测试错误就能提交到远程分支仓库了

搭载 lint-staged 让你飞

以上基本实现我们所需要的,但是...现实的情况是,有些场景我们会接手他人项目,如果按上面步骤走,每次提交代码就会检查所有代码(上面例子只检查 js 的代码)就会发现有 n 个文件有警告或错误(成百上几个),瞬间处于崩溃边缘,想重构或跑路节奏。

lint-staged 当然就是帮助我们解决这类场景问题的,它的作用是指检查当前改动的文件(或者说当天要提交到本地仓库的文件)。

安装依赖包

npm install lint-staged prettier -D
// 或
yarn add lint-staged prettier -D
复制代码

编写

{
    "scripts": {
        "lint:js": "# 检查 js \n  eslint ./src/**/*.js",
        "test": "# 单元测试 \n cross-env NODE_ENV=test mocha tests/"
    },
    "husky": {
        "hooks": {
            "pre-commit": "lint-staged",
            "pre-push": "npm run test"
        }
    },
    "lint-staged": {
        "src/**/*.js": [
            "prettier --tab-width 4 --write",
            "eslint --fix",
            "git add -A"
        ],
       "src/**/*.{css, less}": [
           "prettier --tab-width 4 --write",
            "stylelint --fix",
            "git add -A"
       ]
    }
}

复制代码

剖析

执行

git commit -am "本次提交解释说明"
复制代码

假如 src/utils 目录下有 request.jsindex.js 两个文件,其中两个文件代码都有错误,但是 index.js 是别人写的,属于历史版本(之前怎么提交到仓库或许是因为没做检查或者跳过检查了吧)。本次其实只改动了 request.js 文件,如果按照前面步骤,就会检查出两个文件都有问题,而这又不是我们想要的,因为 index.js 文件不是我写的,里面的代码不好改动(业务逻辑和功能逻辑不明白),这个时候,lint-staged 的价值就体现出来了。

npm script 应用在 git hooks 中

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法心得:高效算法的奥秘(原书第2版)

算法心得:高效算法的奥秘(原书第2版)

(美)Henry S. Warren, Jr. / 爱飞翔 / 机械工业出版社 / 2014-3 / 89.00

【编辑推荐】 由在IBM工作50余年的资深计算机专家撰写,Amazon全五星评价,算法领域最有影响力的著作之一 Google公司首席架构师、Jolt大奖得主Hoshua Bloch和Emacs合作创始人、C语言畅销书作者Guy Steele倾情推荐 算法的艺术和数学的智慧在本书中得到了完美体现,书中总结了大量高效、优雅和奇妙的算法,并从数学角度剖析了其背后的原理 【读者评价......一起来看看 《算法心得:高效算法的奥秘(原书第2版)》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具