欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vite?vue3?規(guī)范化與Git?Hooks詳解

 更新時(shí)間:2022年10月15日 11:22:08   作者:程序員優(yōu)雅哥(\/同)  
這篇文章主要介紹了vite?vue3?規(guī)范化與Git?Hooks,本文重點(diǎn)討論?git?提交規(guī)范,結(jié)合示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

發(fā)展不斷融入很多后端思想,形成前端的“四個(gè)現(xiàn)代化”:工程化、模塊化、規(guī)范化、流程化。在該系列文章中已詳細(xì)介紹了模塊化的發(fā)展及四種模塊化規(guī)范。本文簡單聊聊規(guī)范化中的 git 規(guī)范。

1 規(guī)范化

在企業(yè)級(jí)開發(fā)中,“一千個(gè)讀者有一千個(gè)哈姆雷特”是很常見的事,每個(gè)程序員對技術(shù)的理解、視角和掌握程度參差不齊,導(dǎo)致編寫的代碼五花八門。規(guī)范化包括很多,我在企業(yè)實(shí)踐中重點(diǎn)關(guān)注兩個(gè)方面:代碼規(guī)范 和 git 提交規(guī)范。

代碼規(guī)范最基礎(chǔ)的是代碼格式,不同的代碼格式雖然運(yùn)行起來沒有問題,但代碼超級(jí)難看,代碼亂七八糟、一堆 warning,雖然不影響運(yùn)行,但看著太惡心,就像下面的情形:

  • 估計(jì)是為了節(jié)省紙張,空格全省略,代碼全擠在一起
const a=b+c

const fn=()=>{}

fn(){}

for(let i=0; i<10; i++){}
  • 單引號(hào)、雙引號(hào)混合使用,上一行用單引號(hào),下一行偏要用雙引號(hào);
  • 上一行加分號(hào),后一行省略分號(hào);
  • 定義了一些從沒有使用的變量;
  • 分支判斷中只有一句話堅(jiān)決不寫花括號(hào);
  • ......

我不能說上面的風(fēng)格是錯(cuò)誤的(寫代碼就像玩音樂一樣,不能說絕對的對錯(cuò),只是理解不同罷了),無論怎么寫,至少一個(gè)團(tuán)隊(duì)還是應(yīng)該保證統(tǒng)一的風(fēng)格吧。于是咱們就使用了 .editorconfig 和 eslint。

.editorconfig 對編輯器的基本格式做了限制,但比較粗糙;eslint 就進(jìn)行了詳細(xì)的約束。無論選擇 standard 、airbnb、prettier 任何一種,都是為了強(qiáng)制團(tuán)隊(duì)使用統(tǒng)一的代碼風(fēng)格。

在 《創(chuàng)建 vite vue3 項(xiàng)目》一文中已討論了如何在基于 vite 的 vue3 項(xiàng)目中如何整合 eslint。

本文重點(diǎn)討論 git 提交規(guī)范。

2 git 提交規(guī)范

大家應(yīng)該都是使用 git 管理代碼吧?如果你在企業(yè)還是使用 SVN 管理代碼,那可以趕快跑路了。git 提交代碼使用 git commit -m '描述' 命令。但描述信息很多情況下都是隨意填寫,git 提交規(guī)范就是針對這個(gè)描述信息的約束。

2.1 Angular 規(guī)范

Angular 團(tuán)隊(duì)規(guī)范是目前使用較多的 git 提交規(guī)范 —— 約定式提交。規(guī)范要求提交的描述信息格式為:

<type>[optional scope]: <description>

[optional body]

[optional footer(s)]

含有 optional 表示可選,故必填的內(nèi)容是 type 和 description。

type 表示這次提交的類型,包括如下值:

type含義
feat新功能
fix修復(fù)
docs文檔變更
style代碼格式(不影響代碼運(yùn)行)
refactor重構(gòu)(不增加新功能,也不是修改 bug)
perf性能優(yōu)化
test添加測試
chore修改構(gòu)建過程或輔助工具
revert回退
build打包

例如,實(shí)現(xiàn)了一個(gè)修改用戶列表功能,此時(shí)提交代碼使用如下命令:

git commit -m 'feat: 實(shí)現(xiàn)用戶列表'

修改了 vite.config.ts 的配置,壓縮打包文件:

git commit -m 'chore: 修改vite生產(chǎn)配置'

2.2 Commitizen

確定了git 提交時(shí)描述信息的規(guī)范,那如何讓人遵守執(zhí)行呢?首先需要讓開發(fā)同事知道提交信息的內(nèi)容,此時(shí)可以使用工具 commitizen 來完成。commitizen 是一個(gè) git 提交規(guī)范化的工具,提供了 git cz 命令來代替?zhèn)鹘y(tǒng)的 git commit 命令。使用 git cz 來提交代碼,commitizen 會(huì)一步步提示輸入的字段,并提交所填寫的必需字段。換句話說,使用 git cz 命令,底層最后會(huì)執(zhí)行 git commit,但在執(zhí)行 git commit 前,會(huì)校驗(yàn)描述信息是否符合規(guī)范。如果不符合規(guī)范,則不會(huì)執(zhí)行 git commit,提交失敗。

1.全局安裝 commitizen

yarn global add commitizen

2.在工程中安裝 cz-conventional-changelog

yarn add cz-conventional-changelog -D

3.在工程中初始化 commitizen 的約定式提交:

commitizen init cz-conventional-changelog --yarn --dev --exact

執(zhí)行完該命令,package.json 文件中會(huì)自動(dòng)生成如下配置:

"config": {
  "commitizen": {
    "path": "./node_modules/cz-conventional-changelog"
  }
}

完成上述步驟后,便可以使用 git cz 命令來提交代碼了。

添加需要提交的文件,添加文件后執(zhí)行 git cz 命令,提示如下:

使用上下鍵選擇提交的類型,按照提示輸入相關(guān)內(nèi)容或必填內(nèi)容即可完成提交。

3 git hooks

上面實(shí)現(xiàn)了 Git 提交規(guī)范,但仍然有不聽話的同學(xué)會(huì)使用 git commit,如此一來提交信息依舊是亂七八糟的,此時(shí)便需要使用 git hooks 了。

3.1 什么是 git hooks

hooks 意思是“鉤子”,也就是在執(zhí)行某個(gè)操作之前或之后要做的事。git hooks 就是 git 操作的鉤子,在 git 執(zhí)行某個(gè)操作之前或之后要做的事,如 git 提交后、提交后、合并前、合并后、rebase前、rebase后等。在這里需要重點(diǎn)關(guān)注的 git 鉤子有兩個(gè):

1.pre-commit

pre-commit 是 git commit 執(zhí)行前的鉤子,會(huì)在獲取提交描述信息且提交前被調(diào)用,根據(jù)該鉤子決定是否拒絕提交??梢栽谶@個(gè)鉤子中對代碼進(jìn)行 eslint 檢查。

2.commit-msg

commit-msg 也是 git commit 執(zhí)行前的鉤子,用來規(guī)范化標(biāo)準(zhǔn)格式,根據(jù)標(biāo)準(zhǔn)和提交的描述信息決定是否拒絕提交。可以在這個(gè)鉤子中檢查提價(jià)信息是否符合規(guī)范。

3.2 commitlint 和 husky

理解 git hooks 后,就是如何在工程中引入上述鉤子。此時(shí)需要使用到 husky 和 commitlint。兩者結(jié)合起來可以在提交的描述信息不規(guī)范時(shí)會(huì)導(dǎo)致提交失敗,并提示錯(cuò)誤。首先安裝配置 commitlint。

1.安裝 husky 和 commitlink 相關(guān)依賴:

yarn add husky @commitlint/cli @commitlint/config-conventional -D

2.在項(xiàng)目根目錄創(chuàng)建 commitlint.config.cjs 配置文件:

module.exports = {
  extends: [
    '@commitlint/config-conventional'
  ]
}

3.初始化 husky

npx husky install

執(zhí)行完成后,項(xiàng)目根目錄會(huì)自動(dòng)生成一個(gè) .husky 文件夾。

3.3 pre-commit 和 commit-msg 鉤子

接下來需要使用 lint-staged 對git 暫存區(qū)(git add . 的內(nèi)容)文件進(jìn)行 eslint 檢查。

1.安裝 lint-staged

yarn add lint-staged -D

2.在 package.json 中添加 scripts:

"scripts": {
  ...
  "lint": "eslint \"src/**/*.{js,ts,vue,jsx,tsx}\" --fix"
},

3.在 package.json 添加 lint-staged 配置:

{
	.....
  "lint-staged": {
    "*.{js,ts,jsx,tsx,vue}": [
      "npm run lint"
    ]
  }
}

4.分別執(zhí)行下列命令,為 husky 添加 commit 前的 hook,讓其執(zhí)行 eslint 和 commitlint :

npx husky add .husky/pre-commit 'npx lint-staged'

npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'

執(zhí)行完該命令后,會(huì)自動(dòng)在 .husky/ 目錄下生成 pre-commi 文件和 commit-msg 文件。

pre-commit 文件內(nèi)容如下:

#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"

npx lint-staged

commit-msg 文件內(nèi)容如下:

#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"

npx --no-install commitlint --edit ""

3.4 測試

到此為止便完成了配置,可以按如下步驟進(jìn)行測試:

git add .
git commit -m '測試提交'

控制臺(tái)會(huì)出現(xiàn)如下錯(cuò)誤提示:

使用 git cz 命令重新提交,便可以成功提交。

各位還可以弄點(diǎn) eslint 錯(cuò)誤再提交試試效果。

到此這篇關(guān)于vite vue3 規(guī)范化與Git Hooks的文章就介紹到這了,更多相關(guān)vue3 Git Hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue項(xiàng)目報(bào)錯(cuò):Uncaught SyntaxError: Unexpected token <

    Vue項(xiàng)目報(bào)錯(cuò):Uncaught SyntaxError: Unexpected token <

    這篇文章主要介紹了Vue項(xiàng)目報(bào)錯(cuò):Uncaught SyntaxError: Unexpected token <,在引入第三方依賴的 JS 文件時(shí),遇到的一個(gè)問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue+Cesium快速搭建的方法步驟(無需配置)

    Vue+Cesium快速搭建的方法步驟(無需配置)

    本文主要介紹了Vue+Cesium快速搭建的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • 一文詳解Vue.js與TypeScript的生命周期

    一文詳解Vue.js與TypeScript的生命周期

    Vue與TypeScript的結(jié)合使得開發(fā)大型應(yīng)用變得更加容易和高效,本文將詳細(xì)探討Vue.js組件中TypeScript的應(yīng)用,特別是它的生命周期鉤子函數(shù),并通過豐富的示例,為你提供一個(gè)實(shí)戰(zhàn)指南,需要的朋友可以參考下
    2023-11-11
  • 項(xiàng)目部署后前端vue代理失效問題解決辦法

    項(xiàng)目部署后前端vue代理失效問題解決辦法

    這篇文章主要給大家介紹了關(guān)于項(xiàng)目部署后前端vue代理失效問題的解決辦法,文中通過圖文以及代碼示例將解決的辦法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-02-02
  • 如何利用Vue+Element做個(gè)小頁面

    如何利用Vue+Element做個(gè)小頁面

    vue使用element寫東西讓我感覺到了特別的方便,下面這篇文章主要給大家介紹了關(guān)于如何利用Vue+Element做個(gè)小頁面的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • Vue.js中安裝一個(gè)路由器demo

    Vue.js中安裝一個(gè)路由器demo

    這篇文章主要為大家介紹了Vue.js中安裝一個(gè)路由器demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • vue中的el-button樣式自定義方式

    vue中的el-button樣式自定義方式

    這篇文章主要介紹了vue中的el-button樣式自定義方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue Promise的axios請求封裝詳解

    Vue Promise的axios請求封裝詳解

    這篇文章主要介紹了Vue Promise的axios請求封裝詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • vue-cli3.0項(xiàng)目打包后如何修改訪問后端地址

    vue-cli3.0項(xiàng)目打包后如何修改訪問后端地址

    這篇文章主要介紹了vue-cli3.0項(xiàng)目打包后如何修改訪問后端地址,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 淺談Vue的加載順序探討

    淺談Vue的加載順序探討

    本篇文章主要介紹了Vue的加載順序探討,詳細(xì)的介紹了加載順序以及如何判斷所有的子組件加載完成。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10

最新評論