前端代碼格式自動(dòng)化處理:eslint + stylelint + prettier

前端項(xiàng)目開(kāi)發(fā)過(guò)程中,由于團(tuán)隊(duì)成員每個(gè)人的開(kāi)發(fā)習(xí)慣和代碼風(fēng)格不同从铲,最終提交到git倉(cāng)庫(kù)的代碼格式不統(tǒng)一對(duì)團(tuán)隊(duì)間的協(xié)作產(chǎn)生阻礙冠王,因此使用工具來(lái)自動(dòng)和強(qiáng)制統(tǒng)一代碼格式是一個(gè)好的選擇蚕甥。

Git Hooks

為了保證提交到git倉(cāng)庫(kù)的代碼是整潔、格式統(tǒng)一的炕舵,通常需要使用Git Hooks何之。Git Hooks是在git操作的某些時(shí)機(jī)自動(dòng)執(zhí)行的一些腳本,常見(jiàn)的Git Hookspre-commit咽筋、post-merge溶推、pre-push等。詳情見(jiàn)Git Hooks官方學(xué)習(xí)文檔

Git Hooks存儲(chǔ)在git目錄下的hooks子目錄中悼潭,即絕大部分項(xiàng)目中的 .git/hooks庇忌。如下:

Git Hooks

如果直接去該目錄下編寫(xiě)腳本舞箍,對(duì)于大部分開(kāi)發(fā)人員來(lái)說(shuō)不太友好舰褪,因此在前端項(xiàng)目中可以使用husky這個(gè)npm庫(kù)來(lái)簡(jiǎn)化Git Hooks腳本的編寫(xiě),見(jiàn)https://www.npmjs.com/package/husky疏橄。

husky簡(jiǎn)單介紹
  1. 安裝依賴(lài)
yarn add -D husky
  1. 在package.json里添加要執(zhí)行的git hooks命令占拍,如:
// package.json
{
  "husky": {
    "hooks": {
      "pre-commit": "npm test",
      "post-merge": "sh test.sh",
      "pre-push": "node test.js",
      "...": "..."
    }
  }
}

這里的hooks對(duì)應(yīng).git/hooks下的hooks腳本,里面可以放一些npm命令或者其他自定義的命令捎迫。

lint-staged簡(jiǎn)單介紹

如果要在pre-commit時(shí)自動(dòng)執(zhí)行代碼格式校驗(yàn)晃酒,對(duì)于整個(gè)項(xiàng)目文件執(zhí)行校驗(yàn)命令通常是不合適的,因?yàn)榇a庫(kù)的代碼通常是整潔的窄绒,且每個(gè)提交改動(dòng)的文件一般比較少贝次,因此可以使用lint-staged工具,只對(duì)git暫存區(qū)的文件執(zhí)行腳本彰导。見(jiàn)https://www.npmjs.com/package/lint-staged蛔翅。

  1. 安裝依賴(lài)
yarn add -D lint-staged
  1. 結(jié)合husky,在提交代碼前只對(duì)暫存區(qū)的代碼執(zhí)行命令位谋,配置如下:
// package.json
{
  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  },
  "lint-staged": {
    "*.{js}": [
      "sh test.sh"
    ]
  },
}

lint-staged會(huì)自動(dòng)將暫存區(qū)的文件當(dāng)作參數(shù)拼接在要執(zhí)行的命令后面山析,以上命令相當(dāng)于執(zhí)行sh test.js ${files},對(duì)于v10.x之后的版本掏父,還會(huì)在執(zhí)行命令后自動(dòng)執(zhí)行git add命令笋轨。

eslint

見(jiàn)https://eslint.org/docs/user-guide/getting-started

prettier

見(jiàn)https://prettier.io/docs/en/install.html

與eslint集成見(jiàn)https://prettier.io/docs/en/integrating-with-linters.html

stylelint

見(jiàn)https://stylelint.io/user-guide/get-started

editorconfig

見(jiàn)https://editorconfig.org/,需配合編輯器插件生效

vscode支持eslint和stylelint的配置

vscode插件安裝

配置settings.json

{
    "css.validate": false,
    "less.validate": false,
    "scss.validate": false,
    "editor.codeActionsOnSave": {
        "source.fixAll.eslint": true,
        "source.fixAll.stylelint": true
    },
   "stylelint.validate": [
        "css",
        "less",
        "postcss",
        "sass",
        "scss"
    ]
}

常用基礎(chǔ)配置(方便拷貝)

文件清單

  • .eslintrc
  • .prettierrc
  • .stylelintrc.json
  • package.json
  • .editorconfig
// .eslintrc
{
  "extends": ["plugin:prettier/recommended"],
  "rules": {
    "prettier/prettier": "warn"
  }
}
// .prettierrc
{
  "singleQuote": true,
  "trailingComma": "all",
  "tabWidth": 2,
  "useTabs": false,
  "printWidth": 100,
  "overrides": [
    {
      "files": ".prettierrc",
      "options": { "parser": "json" }
    }
  ]
}
// .stylelintrc.json
{
  "extends": "stylelint-config-standard",
  "rules": {
    "color-no-invalid-hex": true,
    "block-no-empty": true,
    "selector-pseudo-class-no-unknown": [ true, {
      "ignorePseudoClasses": ["global"]
    } ]
  }
}
// package.json
// scripts里的命令用于手動(dòng)校驗(yàn)
{
  "scripts": {
    "lint": "eslint src/**/*.{js,jsx} --fix",
    "lint:style": "stylelint src/**/*.{css,less} --fix"
  },
  "devDependencies": {
    "eslint": "^5.4.0",
    "eslint-config-prettier": "^6.11.0",
    "husky": "^4.2.5",
    "lint-staged": "^10.2.2",
    "stylelint": "^13.3.3",
    "stylelint-config-standard": "^20.0.0"
  },
  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  },
  "lint-staged": {
    "*.{js,jsx}": [
      "eslint --fix --max-warnings 0"
    ],
    "*.{css,less}": [
      "stylelint --fix --max-warnings 0"
    ]
  }
}
# .editorconfig
# http://editorconfig.org
root = true

[*]
indent_style = space
indent_size = 2
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true

[*.md]
trim_trailing_whitespace = false

[Makefile]
indent_style = tab

umi項(xiàng)目的eslint配置和插件列表

// .eslintrc
{
  "extends": ["eslint-config-umi", "plugin:prettier/recommended"],
  "rules": {
    "prettier/prettier": "warn",
    "react-hooks/exhaustive-deps": "off",
    "jsx-a11y/anchor-is-valid": "off",
    "eqeqeq": "off"
  }
}
{
  "devDependencies": {
    "babel-eslint": "^9.0.0",
    "eslint": "^5.4.0",
    "eslint-config-prettier": "^6.11.0",
    "eslint-config-umi": "^1.4.0",
    "eslint-plugin-flowtype": "^2.50.0",
    "eslint-plugin-import": "^2.14.0",
    "eslint-plugin-jsx-a11y": "^5.1.1",
    "eslint-plugin-prettier": "^3.1.3",
    "eslint-plugin-react": "^7.11.1",
  }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末赊淑,一起剝皮案震驚了整個(gè)濱河市爵政,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌陶缺,老刑警劉巖茂卦,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異组哩,居然都是意外死亡等龙,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)伶贰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蛛砰,“玉大人,你說(shuō)我怎么就攤上這事黍衙∧喑” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵琅翻,是天一觀的道長(zhǎng)位仁。 經(jīng)常有香客問(wèn)我柑贞,道長(zhǎng),這世上最難降的妖魔是什么聂抢? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任钧嘶,我火速辦了婚禮,結(jié)果婚禮上琳疏,老公的妹妹穿的比我還像新娘有决。我一直安慰自己,他們只是感情好空盼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布书幕。 她就那樣靜靜地躺著,像睡著了一般揽趾。 火紅的嫁衣襯著肌膚如雪台汇。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,165評(píng)論 1 299
  • 那天篱瞎,我揣著相機(jī)與錄音苟呐,去河邊找鬼。 笑死奔缠,一個(gè)胖子當(dāng)著我的面吹牛掠抬,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播校哎,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼两波,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了闷哆?” 一聲冷哼從身側(cè)響起腰奋,我...
    開(kāi)封第一講書(shū)人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎抱怔,沒(méi)想到半個(gè)月后劣坊,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屈留,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年局冰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灌危。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡康二,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出勇蝙,到底是詐尸還是另有隱情沫勿,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站产雹,受9級(jí)特大地震影響诫惭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蔓挖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一夕土、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧时甚,春花似錦隘弊、人聲如沸哈踱。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)开镣。三九已至刀诬,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間邪财,已是汗流浹背陕壹。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留树埠,地道東北人糠馆。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像怎憋,于是被迫代替她去往敵國(guó)和親又碌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353