news 2026/4/15 12:08:18

.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/8 20:29:04

收藏必读!大模型行业应用全攻略:从通用到垂直的技术落地指南

行业大模型是弥合通用大模型与行业需求差距的产物,具有高性价比、专业定制和数据安全可控等优势。不同行业应用处于不同阶段,产业链两端进展较快。评估应避免将技术指标作为唯一标准,关注业务、技术指标相对提升。技术实现方式包括提示工程、…

作者头像 李华
网站建设 2026/4/15 9:15:15

性能测试实战宝典:从问题定位到优化的一站式解决方案

性能测试实战宝典:从问题定位到优化的一站式解决方案 掌握科学性能测试方法,让系统瓶颈无处遁形 一、性能测试的常见问题及定位方法内存溢出问题 内存溢出是性能测试中最常见的问题之一,主要包括堆内存溢出、栈内存溢出和永久代/方法区溢出。…

作者头像 李华
网站建设 2026/4/13 16:16:45

部署Qwen3-VL-30B显存需求全解析

Qwen3-VL-30B 显存需求全解析:从参数到生产落地的完整指南 🚀 你有没有试过满怀期待地把 Qwen3-VL-30B 加载进本地环境,结果刚一启动就弹出 OOM(Out of Memory)? 看着“激活参数仅 30B”的宣传语&#xff0…

作者头像 李华
网站建设 2026/4/14 19:45:30

无需API也能对话PDF:Anything-LLM开箱即用的文档助手体验

无需API也能对话PDF:Anything-LLM开箱即用的文档助手体验 在办公室里,一位法务人员正面对一份长达80页的合同草案,眉头紧锁。他不想逐字阅读,只关心“有哪些违约责任条款”“保密期限是多久”。过去,这需要几个小时的人…

作者头像 李华