0

0

Linux git hooks自动校验CSS提交前是否格式化

星夢妙者

星夢妙者

发布时间:2025-11-16 17:19:02

|

822人浏览过

|

来源于php中文网

原创

通过配置Git pre-commit钩子或使用husky + lint-staged,可在提交前自动校验并格式化CSS文件,确保代码风格统一。1. 安装Prettier并配置规则;2. 创建pre-commit脚本检查暂存的CSS文件是否格式化,未格式化则阻断提交;3. 为脚本添加执行权限;4. 推荐用husky和lint-staged替代手动管理,实现自动化格式化与提交,提升团队协作效率。

linux git hooks自动校验css提交前是否格式化

在使用 Git 进行版本控制时,确保团队协作中代码风格统一非常重要。对于 CSS 文件,提交前自动校验是否已格式化,可以通过 Git hooks 实现自动化检查。下面介绍如何在 Linux 环境下配置 pre-commit 钩子,自动校验 CSS 文件是否符合格式规范。

1. 安装代码格式化工具(如 Prettier)

推荐使用 Prettier 来统一格式化代码。确保项目中已安装并配置好 Prettier:

npm install --save-dev prettier

在项目根目录创建或更新 .prettierrc 配置文件,例如:

立即学习前端免费学习笔记(深入)”;

{ "semi": false, "trailingComma": "es5", "tabWidth": 2, "useTabs": false, "printWidth": 80, "singleQuote": true }

2. 创建 pre-commit 钩子脚本

Git 的 pre-commit 钩子会在每次执行 git commit 时运行。我们用它来检查所有将要提交的 CSS 文件是否已经格式化。

进入项目的 .git/hooks 目录:

cd .git/hooks

创建或编辑 pre-commit 脚本:

#!/bin/bash

获取所有暂存的 CSS 文件

STAGED_CSS_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep '.css$')

如果没有暂存的 CSS 文件,直接退出

if [ -z "$STAGED_CSS_FILES" ]; then exit 0 fi

echo "检测到以下 CSS 文件将被提交:" echo "$STAGED_CSS_FILES"

临时保存格式化后的内容进行比对

HAS_UNFORMATTED=false

千图设计室AI海报
千图设计室AI海报

千图网旗下的智能海报在线设计平台

下载

for file in $STAGED_CSS_FILES; do

检查文件是否存在(避免删除等情况)

if [ ! -f "$file" ]; then continue fi

使用 prettier 格式化内容,并与原文件比较

FORMATTED_CONTENT=$(npx prettier --parser css "$file")

if [ "$(cat "$file")" != "$FORMATTED_CONTENT" ]; then echo "错误:文件 $file 未格式化,请先运行 prettier 格式化。" HAS_UNFORMATTED=true fi done

如果存在未格式化的文件,阻止提交

if [ "$HAS_UNFORMATTED" = true ]; then echo "提交被拒绝。请先格式化 CSS 文件。" exit 1 fi

exit 0

3. 设置钩子可执行权限

确保 pre-commit 脚本有执行权限:

chmod +x pre-commit

4. (可选)推荐使用 husky + lint-staged 提高可维护性

手动管理 Git hooks 不便于团队共享。建议使用 huskylint-staged 自动化管理钩子。

安装依赖:

npm install --save-dev husky lint-staged

在 package.json 中添加配置:

"husky": { "hooks": { "pre-commit": "lint-staged" } }, "lint-staged": { "*.css": [ "prettier --write", "git add" ] }

这样,每次提交 CSS 文件时会自动格式化并重新加入暂存区,无需手动处理。

基本上就这些。通过 Git hooks 或 husky 配合 Prettier,可以有效防止未格式化的 CSS 被提交,提升代码一致性。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

503

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

261

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

734

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

535

2023.08.01

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

CSS教程
CSS教程

共754课时 | 17.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号