git?hooks的作用及創(chuàng)建使用示例詳解
1. 什么是git hooks ?有什么用?。?/h2>
1.1 是個(gè)啥
git大家都在用吧,相信現(xiàn)在沒公司代碼不做版本控制的吧。git hooks是git提供的,在發(fā)生特定事件時(shí),允許用戶添加自定義代碼(或操作)的方式。
就像Vue中組件的生命周期鉤子,比如,你想在vue組件創(chuàng)建后輸出一行log, 你可能會(huì)這么寫
export default {
created () {
console.log('Hello I am created.')
}
}
1.2 有啥用?我以前沒用過它不也一樣好好的嗎?我干嘛要用它?
- 你在git commit -m "feat: 修復(fù)bug=51234"時(shí),總是提交的很規(guī)范,很明確自己提交了什么,但是團(tuán)隊(duì)中有人提交時(shí)只寫一個(gè)
git commit -m "add",你也看不出來他提交了啥,這時(shí)候就可以使用commit-msg鉤子去限定下,提交信息必須符合某種格式,否則不允許提交 - 你喜歡
js代碼縮進(jìn)用兩個(gè)空格,但是團(tuán)隊(duì)中有人總是兩個(gè)空格和四個(gè)空格混用,十分的混亂,這時(shí)候就可以結(jié)合eslint,在提交前進(jìn)行代碼格式的校驗(yàn)
2. 怎么創(chuàng)建一個(gè) git hooks ?
2.1 首先看git hooks存在哪里
git hooks其實(shí)就存在倉庫根目錄中的.git/hooks/目錄中(.git目錄可能是隱藏目錄,取消隱藏即可查看),我們來看下默認(rèn)的.git/hooks/目錄是什么樣子

發(fā)現(xiàn)了嗎,git在初始化倉庫的時(shí)候,很貼心的為你初始化了很多個(gè)xxx.sample文件(這些文件不會(huì)被執(zhí)行),就是鉤子的示例文件,比如pre-commit.sample就是git commit前的鉤子示例文件。
2.2 創(chuàng)建一個(gè)pre-commit鉤子
為了更容易理解,讓我們?cè)O(shè)定一個(gè)場(chǎng)景:比如,你想在git commit 前在命令行輸出一個(gè) Hello world
在 .git/hooks/中將pre-commit.sample文件復(fù)制一份,刪除文件后綴名,文件名變?yōu)?code>pre-commit,刪除除第一行以外的內(nèi)容
#!/bin/sh # 以下為shell語法 echo "Hello world"
2.3 觸發(fā)鉤子
我們剛剛創(chuàng)建的是提交前的鉤子,那么我們要觸發(fā)它,就必須得提交代碼(即執(zhí)行git commit)
在根目錄中創(chuàng)建一個(gè)文件 1.js
var a = 12
創(chuàng)建后目錄結(jié)構(gòu)
study ├── .git │ ├── hooks │ │ ├── pre-commit └── 1.js
添加進(jìn)暫存區(qū)
git add .
提交
git commit -m "我新建了一個(gè)1.js"
此時(shí)命令行輸出

你看上面打出了 "Hello world",喲呼,我們創(chuàng)建了自己的第一個(gè)git hooks,給自己點(diǎn)個(gè)贊?。。?!
3 有用點(diǎn)的實(shí)戰(zhàn)
需求場(chǎng)景
假設(shè),我們不允許在提交信息中包含"大白"這種詞匯,那么我們可以怎么做?
在.git/hooks 中新建commit-msg文件, 編寫 .git/hooks/commit-msg 文件內(nèi)容
- node版
#!/usr/bin/env node
const fs = require('fs');
// 索引 2 對(duì)應(yīng)的 commit 消息文件 里面包含提交信息
// 就是你在 git commit -m "msg" 時(shí)輸入的 msg
const msg = fs.readFileSync(process.argv[2], 'utf-8').trim();
// 判斷 commit_msg中是否包含 "大白"
// 若包含,則中斷git的流程
if (msg.indexOf('大白') > -1) {
console.error('您的提交信息中包含【大白】這個(gè)詞匯,請(qǐng)檢查!');
// exit 1 表示程序執(zhí)行異常退出 中斷git的流程 不允許提交
process.exit(1);
} else {
console.log('不包含')
}
- shell 版
#!/bin/sh # 獲取當(dāng)前提交的 commit msg 內(nèi)容 # 就是你在 git commit -m "msg" 時(shí)輸入的 msg # 用 `` 可以將命令的輸出結(jié)果賦值給變量 commit_msg # $1 是git在執(zhí)行鉤子時(shí)提供給我們的參數(shù),就是你在 git commit -m "msg" 時(shí)輸入的 msg commit_msg=`cat $1` # 輸出下獲取到的提交注釋 echo "您提交的commit_msg: $commit_msg" # 判斷 commit_msg中是否包含 "大白" # 若包含,則中斷git的流程 if [[ $commit_msg =~ "大白" ]] then echo "您的提交信息中包含【大白】這個(gè)詞匯,請(qǐng)檢查!" # exit 1 表示程序執(zhí)行異常退出 中斷git的流程 不允許提交 exit 1 else echo "不包含" fi
修改 1.js
var a = 12333
添加進(jìn)暫存區(qū)
git add .
提交
git commit -m "我新建了一個(gè)1.js,大白"
運(yùn)行結(jié)果

4 總結(jié)
其實(shí)就是git就是在用戶做特定事情的時(shí)候,去查找.git/hooks/,目錄中查找對(duì)應(yīng)事件的鉤子文件是否存在,若存在就執(zhí)行這個(gè)鉤子文件中的shell腳本(上面的例子中就是git在用戶執(zhí)行git commit操作的時(shí)候,找到了pre-commit文件并執(zhí)行了其中的shell )
5 其他
5.1 如果在mac下報(bào)以下異常
hint: The ‘.git/hooks/pre-auto-gc’ hook was ignored because it’s not set as executable.
hint: You can disable this warning with git config advice.ignoredHook false.
那是因?yàn)樵趍ac下文件默認(rèn)是不可執(zhí)行的,執(zhí)行以下操作即可
chmod 777 .git/hooks/commit-msg
5.2 常用鉤子
pre-commit 提交前 commit-msg 提交信息 pre-push push前
更多文檔請(qǐng)參看點(diǎn)我去官網(wǎng)看
5.3 hooks可以使用什么語言?
用于編寫 git hooks 的腳本語言是沒有限制的,你可以用 nodejs、shell、python、ruby等腳本語言,非常的靈活方便。文中我使用的是shell
以上就是git hooks的作用及創(chuàng)建使用示例詳解的詳細(xì)內(nèi)容,更多關(guān)于git hooks創(chuàng)建使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序之頁面跳轉(zhuǎn)和參數(shù)傳遞的實(shí)現(xiàn)
這篇文章主要介紹了微信小程序之頁面跳轉(zhuǎn)和參數(shù)傳遞的實(shí)現(xiàn)的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09
微信小程序 轉(zhuǎn)發(fā)功能的實(shí)現(xiàn)
這篇文章主要介紹了微信小程序 轉(zhuǎn)發(fā)功能的實(shí)現(xiàn)的相關(guān)資料,這里提供實(shí)現(xiàn)方法及實(shí)例幫助大家學(xué)習(xí)理解,需要的朋友可以參考下2017-08-08
JavaScript前端實(shí)現(xiàn)小說分頁功能示例
這篇文章主要為大家介紹了JavaScript前端實(shí)現(xiàn)小說分頁功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
微信小程序之MaterialDesign--input組件詳解
本篇文章主要介紹了微信小程序之MaterialDesign--input組件詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02

