eslint + pre-commit檢測(cè)代碼

良好的代碼規(guī)范有助于項(xiàng)目的維護(hù)和新人的快速上手践磅。前段時(shí)間姆蘸,把eslint引入了項(xiàng)目中做靜態(tài)代碼檢查官扣。 一下把所有的代碼都改造是不可能翅敌,要改的地方太多,而且要保證后來(lái)提交代碼的質(zhì)量惕蹄。于是有了eslint + pre-commit 的結(jié)合蚯涮。
  pre-commit是git的鉤子治专,顧名思義就是在提交前運(yùn)行,所以一般用于代碼檢查遭顶、單元測(cè)試张峰。git還有其他鉤子,比如prepare-commit-msg棒旗、pre-push等喘批,具體可查看git官網(wǎng)。git 鉤子目錄在.git/hooks下(如下圖):

git-hooks.png

  上圖這些文件都是對(duì)應(yīng)鉤子的示例腳本铣揉,.sample后綴都是出于未啟動(dòng)狀態(tài)饶深。對(duì)應(yīng)的鉤子要生效,把.sample去掉逛拱。示例都是用shell腳本寫(xiě)的敌厘。那如果想用js寫(xiě)怎么辦呢?需要借助pre-commit庫(kù)

  1. 安裝pre-commit
npm install pre-commit --save-dev
  1. 配置package.json
  • 執(zhí)行靜態(tài)文件檢查
// package.json
"scripts": {
    "lint": "eslint src --ext .js --cache --fix",
  },
  "pre-commit": [
    "lint",
  ]

上面配置會(huì)保證eslint在提交時(shí)會(huì)校驗(yàn)src目錄下的js文件朽合。
那如果要?jiǎng)討B(tài)獲取提交的代碼進(jìn)行校驗(yàn)?zāi)兀?/p>

  • 校驗(yàn)提交代碼
// 獲取修改后的js文件
git diff HEAD --name-only| grep .js$

package.json文件可改為:

// package.json
"scripts": {
     "lint": "eslint src --ext .js --cache --fix",
     "pre-lint": "node check.js"
},
"pre-commit": [
     "pre-lint",
]

在check.js中需要調(diào)用eslint的Node.js API俱两,詳情可看eslint官網(wǎng)。以下是我在項(xiàng)目中的例子曹步,可作為參考:

// check.js
const exec = require('child_process').exec
const CLIEngine = require('eslint').CLIEngine
const cli = new CLIEngine({})
function getErrorLevel(number) {
       switch (number) {
          case 2:
            return 'error'
          case 1:
            return 'warn'
         default:
       }
       return 'undefined'
}
let pass = 0
exec('git diff --cached --name-only| grep .js$', (error, stdout) => {
    if (stdout.length) {
        const array = stdout.split('\n')
        array.pop()
        const results = cli.executeOnFiles(array).results
        let errorCount = 0
        let warningCount = 0
        results.forEach((result) => {
            errorCount += result.errorCount
            warningCount += result.warningCount
            if (result.messages.length > 0) {
                console.log('\n')
                console.log(result.filePath)
                result.messages.forEach((obj) => {
                    const level = getErrorLevel(obj.severity)
                    console.log(`   ${obj.line}:${obj.column}  ${level}  ${obj.message}  ${obj.ruleId}`)
                    pass = 1
                })
            }
        })
        if (warningCount > 0 || errorCount > 0) {
            console.log(`\n   ${errorCount + warningCount} problems (${errorCount} ${'errors'} ${warningCount} warnings)`)
        }
        process.exit(pass)
    }
    if (error !== null) {
        console.log(`exec error: ${error}`)
    }
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末宪彩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子讲婚,更是在濱河造成了極大的恐慌尿孔,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件磺樱,死亡現(xiàn)場(chǎng)離奇詭異纳猫,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)竹捉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)尚骄,“玉大人块差,你說(shuō)我怎么就攤上這事【笳桑” “怎么了憨闰?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)需五。 經(jīng)常有香客問(wèn)我鹉动,道長(zhǎng),這世上最難降的妖魔是什么宏邮? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任泽示,我火速辦了婚禮缸血,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘械筛。我一直安慰自己捎泻,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布埋哟。 她就那樣靜靜地躺著笆豁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪赤赊。 梳的紋絲不亂的頭發(fā)上闯狱,一...
    開(kāi)封第一講書(shū)人閱讀 49,111評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音抛计,去河邊找鬼扩氢。 笑死,一個(gè)胖子當(dāng)著我的面吹牛爷辱,可吹牛的內(nèi)容都是我干的录豺。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼饭弓,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼双饥!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起弟断,我...
    開(kāi)封第一講書(shū)人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤咏花,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后阀趴,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體昏翰,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年刘急,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了棚菊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叔汁,死狀恐怖统求,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情据块,我是刑警寧澤码邻,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站另假,受9級(jí)特大地震影響像屋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜边篮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一己莺、第九天 我趴在偏房一處隱蔽的房頂上張望奏甫。 院中可真熱鬧,春花似錦篇恒、人聲如沸扶檐。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)款筑。三九已至,卻和暖如春腾么,著一層夾襖步出監(jiān)牢的瞬間奈梳,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工解虱, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留攘须,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓殴泰,卻偏偏與公主長(zhǎng)得像于宙,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子悍汛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 什么是 NPM npm之于Node捞魁,就像pip之于Python,gem之于Ruby,composer之于PHP。 ...
    ihoey閱讀 6,248評(píng)論 2 36
  • 單例模式 適用場(chǎng)景:可能會(huì)在場(chǎng)景中使用到對(duì)象离咐,但只有一個(gè)實(shí)例谱俭,加載時(shí)并不主動(dòng)創(chuàng)建,需要時(shí)才創(chuàng)建 最常見(jiàn)的單例模式宵蛀,...
    Obeing閱讀 2,056評(píng)論 1 10
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理昆著,服務(wù)發(fā)現(xiàn),斷路器术陶,智...
    卡卡羅2017閱讀 134,600評(píng)論 18 139
  • 大凡努力的生命凑懂,都讓我為之心生敬意。 一個(gè)小小的生命瞳别,卑微而勤勉地活著征候,它的眼中只有四角的天空,卻在這片天空下自給...
    意念的康橋閱讀 333評(píng)論 0 1
  • 紅日東升兆解、風(fēng)拂柳馆铁,春回大地」Γ看首都埠巨,錦旗飄展历谍,“兩會(huì)"聚議。四面委員攜議案辣垒,八方代表呈民意望侈。銳改革、求索制勝謀勋桶,出...
    e4230d735f98閱讀 281評(píng)論 0 0