news 2026/4/23 9:41:23

.gitignore文件解读

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
.gitignore文件解读

下面是一个.gitignore文件,我们将会对这个文件里的内容进行分类解读,通过本文,你将可以根据需要撰写自己的.gitignore文件。

# Node.js and frontend-related files node_modules/ dist/ *.log *.env yarn.lock package-lock.json .vscode/ .idea/ *.tsbuildinfo # JetBrains IDEs (e.g., IntelliJ IDEA, PhpStorm, WebStorm) .idea/ # OS generated files .DS_Store Thumbs.db # Backend related files *.iml *.jar *.war *.ear *.class # Maven mvnw mvnw.cmd

.gitignore文件 是用来让 Git 自动忽略那些不需要提交到代码仓库的文件 /和文件夹的工具。只要用 Git 管理项目,从项目创建时就要加 .gitignore —— 因为项目里一定会有不需要共享给团队或者提交到仓库的文件。比如说一些环境配置文件、编译产生的文件、系统文件、涉及隐私的文件。

一、斜杠/

  1. 结尾带斜杠(xxx/:仅匹配「文件夹」,不匹配同名文件(比如不会误忽略叫node_modules的文件);
  2. 开头带斜杠(/xxx/:限定「根目录」,非根目录的同名文件夹不匹配;
  3. 无斜杠(node_modules:既匹配文件夹,也匹配同名文件,且匹配所有层级(不推荐,容易误匹配)。
写法匹配范围举例(项目结构)
node_modules/匹配所有层级下的node_modules文件夹(不管在根目录/子目录)根目录node_modules/frontend/node_modules/都会被忽略
/node_modules/仅匹配根目录下的node_modules文件夹只忽略node_modules/,不忽略frontend/node_modules/
frontend/node_modules/仅匹配frontend子目录下的node_modules只忽略frontend/node_modules/,不忽略根目录/其他目录的
node_modules匹配所有层级下的node_modules文件夹和文件夹(不管在根目录/子目录)根目录node_modules/frontend/node_modules/frontend/node_modules.txt都会被忽略

这份.gitignore配置覆盖了文件后缀、文件夹、特定文件名三类匹配规则,核心遵循 Git 官方的.gitignore匹配语法,我按「规则类型+原理+生效范围」拆解,帮你彻底理解每一行的匹配逻辑:

二、 「后缀匹配」:*.xxx

*是「通配符」,匹配任意字符(除路径分隔符/),*.xxx表示「所有层级下后缀为.xxx的文件」。
例如:

配置行匹配原理生效范围
*.log*匹配任意文件名前缀,.log固定后缀 → 匹配所有.log日志文件项目所有目录(根目录/子目录都算)
*.env匹配所有.env环境配置文件(比如根目录.envfrontend/.env所有层级
*.tsbuildinfo匹配 TypeScript 编译生成的.tsbuildinfo文件(如frontend/*.tsbuildinfo所有层级

⚠️ 关键:*.xxx不会匹配「文件夹」(比如不会误忽略名为test.log的文件夹),仅匹配文件。

三、 「精确文件名匹配」:无通配符、无/

直接写文件名(无通配符、无/),表示「匹配所有层级下同名的文件或文件夹」。
例如:

配置行匹配原理生效范围
yarn.lock精确匹配名为yarn.lock的文件(根目录/frontend 下的都算)所有层级
package-lock.json精确匹配 npm 生成的package-lock.json文件(任意目录下)所有层级
mvnw精确匹配名为mvnw的文件(根目录/backend 下的都算)所有层级

⚠️ 注意:这类规则会匹配文件夹(比如如果有个yarn.lock/文件夹,也会被忽略),如果只想匹配文件,可加后缀限定(但这类文件名本身是固定文件,无需额外处理)。

四、 「文件夹匹配」:xxx/

结尾带/是「文件夹专属匹配规则」,表示「匹配所有层级下名为xxx的文件夹」,不会匹配同名文件。
例如:

配置行匹配原理生效范围
.idea/匹配所有层级下的.idea文件夹(JetBrains IDE 生成的配置目录,如根目录/.idea、frontend/.idea)所有层级

⚠️ 补充:如果写成/\.idea/(开头加/),则仅匹配「根目录下的.idea文件夹」,子目录的.idea不会被忽略;你这里写的.idea/是全局匹配,更符合实际需求(所有 IDE 配置目录都该忽略)。

五、 「系统生成文件」:精确文件名

这类是不同操作系统自动生成的无用文件,用「精确文件名」匹配,覆盖所有层级。
例如:

配置行匹配原理生效范围
.DS_Store匹配 macOS 系统生成的文件夹配置文件(任意目录下的.DS_Store所有层级
Thumbs.db匹配 Windows 系统生成的缩略图缓存文件(任意目录下的Thumbs.db所有层级

补充:验证规则是否生效的小技巧

如果不确定某行规则是否匹配目标文件,可执行 Git 命令验证:

# 检查根目录的 .idea 文件夹是否被忽略gitcheck-ignore -v .idea/# 检查 frontend 下的 node_modules 是否被忽略(如果加了 node_modules/ 规则)gitcheck-ignore -v frontend/node_modules/
  • 输出「.gitignore:行号:规则 目标路径」→ 规则生效;
  • 无输出 → 规则未匹配,需调整写法。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 13:06:51

Excalidraw使用技巧:从数据到图表的高效转化

Excalidraw使用技巧:从数据到图表的高效转化 在产品设计与技术协作中,最耗时的往往不是思考本身,而是把脑子里的想法“画出来”。你有没有过这样的经历:会议中刚理清一个系统流程,却因为要手动拖拽十几个方框、连线、…

作者头像 李华
网站建设 2026/4/23 8:17:24

FLUX.1-dev模型本地训练与推理指南(GPU/NPU)

FLUX.1-dev模型本地训练与推理指南(GPU/NPU) 模型简介 FLUX.1-dev 是由 Black Forest Labs 推出的下一代文生图多模态大模型,作为 Stable Diffusion 原班团队的新作,其在生成式人工智能领域树立了新的技术标杆。该模型基于创新的…

作者头像 李华
网站建设 2026/4/23 8:18:57

COBOL编程入门:从基础到文件处理

COBOL编程入门:从基础到文件处理 在银行核心系统的一次深夜故障排查中,运维团队发现一笔关键交易未能入账。经过层层追踪,问题最终指向一段运行了三十年的薪资计算逻辑——代码依然健壮,但能读懂它的人却越来越少。这正是COBOL的真…

作者头像 李华
网站建设 2026/4/23 11:20:03

Ubuntu部署Dify+蓝耘MaaS打造AI应用

在 Ubuntu 上快速构建 RAG 智能客服:Dify 蓝耘 MaaS 实战部署 如今,企业对 AI 的期待早已从“能不能用”转向“能不能落地”。一个典型场景是:客户在官网反复询问套餐价格、开通流程或技术支持方式——这些问题明明有标准答案,却…

作者头像 李华
网站建设 2026/4/23 11:20:59

Stable Diffusion 3.5本地部署与远程访问实战

Stable Diffusion 3.5本地部署与远程访问实战 在生成式AI飞速演进的今天,越来越多创作者和开发者不再满足于使用现成的在线服务。他们更希望拥有一套完全自主控制、可定制、高性能的本地AI绘图系统——既能保护数据隐私,又能摆脱高昂算力成本的束缚。 …

作者头像 李华
网站建设 2026/4/22 2:57:57

孢子捕捉仪孢子捕捉分析系统

孢子自动捕捉系统作为现代农业病害防控的核心装备,通过智能化监测与精准预警机制,为作物健康管理提供科学支撑。该系统集成多项关键技术模块,实现从孢子捕获到数据分析的全流程自动化管理。设备核心驱动单元采用横向与纵向双轴电机协同工作机…

作者头像 李华