vite vue3 規範化與Git Hooks

来源:https://www.cnblogs.com/youyacoder/archive/2022/10/14/16791663.html
-Advertisement-
Play Games

在 《JS 模塊化》系列開篇中,曾提到前端技術的發展不斷融入很多後端思想,形成前端的“四個現代化”:工程化、模塊化、規範化、流程化。在該系列文章中已詳細介紹了模塊化的發展及四種模塊化規範。本文簡單聊聊規範化中的 git 規範。 ...


在 《JS 模塊化》系列開篇中,曾提到前端技術的發展不斷融入很多後端思想,形成前端的“四個現代化”:工程化、模塊化、規範化、流程化。在該系列文章中已詳細介紹了模塊化的發展及四種模塊化規範。本文簡單聊聊規範化中的 git 規範。

1 規範化

在企業級開發中,“一千個讀者有一千個哈姆雷特”是很常見的事,每個程式員對技術的理解、視角和掌握程度參差不齊,導致編寫的代碼五花八門。規範化包括很多,我在企業實踐中重點關註兩個方面:代碼規範git 提交規範

代碼規範最基礎的是代碼格式,不同的代碼格式雖然運行起來沒有問題,但代碼超級難看,代碼亂七八糟、一堆 warning,雖然不影響運行,但看著太噁心,就像下麵的情形:

  • 估計是為了節省紙張,空格全省略,代碼全擠在一起:
const a=b+c

const fn=()=>{}

fn(){}

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

我不能說上面的風格是錯誤的(寫代碼就像玩音樂一樣,不能說絕對的對錯,只是理解不同罷了),無論怎麼寫,至少一個團隊還是應該保證統一的風格吧。於是咱們就使用了 .editorconfigeslint

.editorconfig 對編輯器的基本格式做了限制,但比較粗糙;eslint 就進行了詳細的約束。無論選擇 standardairbnbprettier 任何一種,都是為了強制團隊使用統一的代碼風格。

在 《創建 vite vue3 項目》一文中已討論瞭如何在基於 vite 的 vue3 項目中如何整合 eslint

本文重點討論 git 提交規範。

2 git 提交規範

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

2.1 Angular 規範

Angular 團隊規範是目前使用較多的 git 提交規範 —— 約定式提交。規範要求提交的描述信息格式為:

<type>[optional scope]: <description>

[optional body]

[optional footer(s)]

含有 optional 表示可選,故必填的內容是 typedescription

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

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

例如,實現了一個修改用戶列表功能,此時提交代碼使用如下命令:

git commit -m 'feat: 實現用戶列表'

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

git commit -m 'chore: 修改vite生產配置'

2.2 Commitizen

確定了git 提交時描述信息的規範,那如何讓人遵守執行呢?首先需要讓開發同事知道提交信息的內容,此時可以使用工具 commitizen 來完成。commitizen 是一個 git 提交規範化的工具,提供了 git cz 命令來代替傳統的 git commit 命令。使用 git cz 來提交代碼,commitizen 會一步步提示輸入的欄位,並提交所填寫的必需欄位。換句話說,使用 git cz 命令,底層最後會執行 git commit,但在執行 git commit 前,會校驗描述信息是否符合規範。如果不符合規範,則不會執行 git commit,提交失敗。

  1. 全局安裝 commitizen
yarn global add commitizen
  1. 在工程中安裝 cz-conventional-changelog
yarn add cz-conventional-changelog -D
  1. 在工程中初始化 commitizen 的約定式提交:
commitizen init cz-conventional-changelog --yarn --dev --exact

執行完該命令,package.json 文件中會自動生成如下配置:

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

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

添加需要提交的文件,添加文件後執行 git cz 命令,提示如下:

image-20221010141052575

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

3 git hooks

上面實現了 Git 提交規範,但仍然有不聽話的同學會使用 git commit,如此一來提交信息依舊是亂七八糟的,此時便需要使用 git hooks 了。

3.1 什麼是 git hooks

hooks 意思是“鉤子”,也就是在執行某個操作之前或之後要做的事。git hooks 就是 git 操作的鉤子,在 git 執行某個操作之前或之後要做的事,如 git 提交後、提交後、合併前、合併後、rebase前、rebase後等。在這裡需要重點關註的 git 鉤子有兩個:

  1. pre-commit

pre-commitgit commit 執行前的鉤子,會在獲取提交描述信息且提交前被調用,根據該鉤子決定是否拒絕提交。可以在這個鉤子中對代碼進行 eslint 檢查。

  1. commit-msg

commit-msg 也是 git commit 執行前的鉤子,用來規範化標準格式,根據標準和提交的描述信息決定是否拒絕提交。可以在這個鉤子中檢查提價信息是否符合規範。

3.2 commitlint 和 husky

理解 git hooks 後,就是如何在工程中引入上述鉤子。此時需要使用到 huskycommitlint。兩者結合起來可以在提交的描述信息不規範時會導致提交失敗,並提示錯誤。首先安裝配置 commitlint

  1. 安裝 huskycommitlink 相關依賴:
yarn add husky @commitlint/cli @commitlint/config-conventional -D
  1. 在項目根目錄創建 commitlint.config.cjs 配置文件:
module.exports = {
  extends: [
    '@commitlint/config-conventional'
  ]
}
  1. 初始化 husky
npx husky install

執行完成後,項目根目錄會自動生成一個 .husky 文件夾。

3.3 pre-commit 和 commit-msg 鉤子

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

  1. 安裝 lint-staged
yarn add lint-staged -D
  1. package.json 中添加 scripts
"scripts": {
  ...
  "lint": "eslint \"src/**/*.{js,ts,vue,jsx,tsx}\" --fix"
},
  1. package.json 添加 lint-staged 配置:
{
	.....
  "lint-staged": {
    "*.{js,ts,jsx,tsx,vue}": [
      "npm run lint"
    ]
  }
}
  1. 分別執行下列命令,為 husky 添加 commit 前的 hook,讓其執行 eslintcommitlint
npx husky add .husky/pre-commit 'npx lint-staged'

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

執行完該命令後,會自動在 .husky/ 目錄下生成 pre-commi 文件和 commit-msg 文件。

pre-commit 文件內容如下:

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

npx lint-staged

commit-msg 文件內容如下:

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

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

3.4 測試

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

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

控制台會出現如下錯誤提示:

image-20221010174850827

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

各位還可以弄點 eslint 錯誤再提交試試效果。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近在學著使用blackwidow這個工具,在ubuntu20.02系統的安裝過程當中遇到了selenium使用的一些問題。 selenium是個什麼工具? Selenium是一個用於Web應用程式測試的工具。Selenium測試直接運行在瀏覽器中,就像真正的用戶在操作一樣。支持的瀏覽器包括IE(7 ...
  • Redis核心流程 💡 本文分析基於Redis-1.0源碼,核心流程代碼主要分佈在redis.c,ae.c兩個文件中。 Notion版本 1.Redis核心流程中的重要數據結構 struct redisServer { int port; int fd; redisDb *db; aeEventL ...
  • Navicat是一套快速、可靠和全面的資料庫管理工具,專門用於簡化資料庫管理和降低管理成本。Navicat圖形界面直觀,提供簡便的管理方法,設計和操作MySQL、MariaDB、SQL Server、Oracle、PostgreSQL和SQLite的數據。 navicat 查詢界面字體偏小,看的眼睛 ...
  • 資料庫安裝 選擇全新安裝模式繼續安裝 輸入產品秘鑰:這裡使用演示秘鑰進行 接受許可 規則檢測 可以後期再開放防火牆對外埠 選擇需要安裝的功能,想省事可以選擇【全選】 可以安裝JDK,這邊選擇取消 Polybase 查詢服務 使用預設實例 伺服器配置–預設即可 伺服器配置 Reporting Ser ...
  • 設置MySQL 創建資料庫,預設為UTF-8 下載地址:https://downloads.mysql.com/archives/installer/ 安裝 網站上只有 x86 沒有 x64 位,之前下了 x64 的zip 包,配置比較麻煩,其實這個 x86 包裡面,已經包含了 x64的包 我這邊選 ...
  • 邏輯存儲結構 邏輯存儲結構圖 表空間 表空間文件在Linux下存放在 /var/lib/mysql文件中的 xxx.ibd 文件就是表空間文件 表空間文件用來存儲,記錄,索引等數據。 段 段分為,數據段(Leaf node segment) ,索引段(Non-leaf node segment),回 ...
  • 需要工具: 1、apktool:獲取資源文件,提取圖片文件,佈局文件,還有一些XML的資源文件 2、dex2jar:將APK反編譯成Java源碼(將classes.dex轉化為jar文件) 3、**jd-gui:**查看轉換後的jar文件 1、使用apktool獲得資源文件以及xml文件 1.1、下 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 1.起因 最近有一個需求,需要使用自定義插件,來對接硬體功能,需要配合對手機的許可權進行判斷和提示,併在對接後對本地文件進行操作,這裡給大家分享下我的碰到的問題,廢話不多說,開搞 2.對接自定義插件,製作自定義基座 manifest.jso ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...