不清楚的 .gitignore

起因:

在项目 .gitignore 看见了部分配置如下:

bash 复制代码
node_modules
/dist
.history

/.history/src/views/incomeData/incomePool/list_20230209102341.vue
/.history/src/views/incomeData/incomePool/list_20230209102421.vue
/.history/src/views/incomeData/incomePool/list_20230209102435.vue

.vscode
.vscode/

你是否也觉得这个忽略文件怪怪的,但知识它在脑子里又不那么清楚 🫣

  1. node_modules一般配置是 node_modules/,他们有什么区别?
  2. /dist前面加不加/有区别吗?
  3. 配置过了 .history,后面三条还有必要? 难道 .history配置后内部文件不忽略??
  4. .vscode.vscode/不重复?

下面逐个分析

1. node_modules一般配置是 node_modules/,他们有什么区别?

node_modules:忽略任意层级路径中,名为 node_modules 的路径项

  • 如果该路径项是 文件
    👉 忽略该文件
  • 如果该路径项是 目录
    👉 忽略该目录 及其全部子内容

node_modules/: 忽略任意层级路径中,名为node_modules的目录(及其全部子内容)

虽然它们都能实现忽略 node_modules目录

node_modules规则本身语义不明确,从规则本身无法一眼判断

  • 要忽略文件?
  • 还是忽略目录?

node_modules/一眼就知道要忽略这个目录,所以在忽略目录的时候更推荐这种写法

2. /dist前面加不加/有区别吗?

有区别

dist:忽略任意层级 路径中,名为 dist 的路径项

/dist:忽略根目录 下名为dist的路径项

3. 配置过了 .history,后面三条还有必要? 难道 .history配置后内部文件不忽略?

现在我们已经知道 .history的含义(忽略任意层级路径中,名为 .history 的路径项),

bash 复制代码
/.history/src/views/incomeData/incomePool/list_20230209102341.vue
/.history/src/views/incomeData/incomePool/list_20230209102421.vue
/.history/src/views/incomeData/incomePool/list_20230209102435.vue

很明显这三个文件都是目录 .history下的内容,配置.history已经包含,完全可以删掉这三条.

.history是常见vscode 插件生成的目录,故推荐写法.history/.

4. .vscode.vscode/不重复?

重复

想必到这里已经非常明确的知道他们的区别了(不明白看第一个问题),.vscode是常见 IDE 配置目录,所以推荐.vscode/

成果展示

现在要修改文章开头的 .gitignore,易如反掌

bash 复制代码
node_modules/
dist/
.history/
.vscode/

至于前面要不要加/自行判断需要忽略任意层级路径中的目录 还是仅根目录

扩展

bash 复制代码
# 1️⃣ * 通配符: 匹配任意字符(不含/)
# 忽略所有 .log 结尾的路径项
*.log 


# 2️⃣ !反向忽略
# 2.1 忽略 .vscode 目录下所有内容,但保留项目级 VS Code 配置
.vscode/*
!.vscode/settings.json
# 2.2 忽略所有 .env,但保留示例文件
.env
!.env.example

为什么反向忽略例子2.1用的是.vscode/*而不是.vscode/

用一个例子解释,目录结构:

复制代码
.vscode/
  settings.json
  launch.json

1️⃣ 使用 .vscode/

含义:

忽略名为 .vscode 的目录

一旦该目录被忽略,其内部所有文件都会被隐式忽略

结果:

复制代码
.vscode/            ❌
  settings.json     ❌
  launch.json       ❌

git 已经忽略 .vscode 目录,不会再进入该目录,无论写多少个反向忽略,都没用

2️⃣ 使用 .vscode/*

含义:

忽略 .vscode 目录下的 所有直接子路径

.vscode 目录本身 仍然是"可见的"

结果:

复制代码
.vscode/            ✅
  settings.json     ❌(除非反向忽略)
  launch.json       ❌

在此基础上添加反向忽略,git才能识别.

有趣 🌾

相关推荐
张鑫旭3 小时前
AI时代2025年下半年学的这些Web前端特性有没有用?
前端·ai编程
pinkQQx4 小时前
H5唤醒APP技术方案入门级介绍
前端
Lefan4 小时前
UniApp 隐私合规神器!一键搞定应用市场审核难题 - lf-auth 隐私合规助手
前端
Null1554 小时前
浏览器唤起桌面端应用(进阶篇)
前端·浏览器
Jing_Rainbow4 小时前
【Vue-2/Lesson62(2025-12-10)】模块化与 Node.js HTTP 服务器开发详解🧩
前端·vue.js·node.js
风度前端4 小时前
用了都说好的 uniapp 路由框架
前端
冴羽4 小时前
2026 年 Web 前端开发的 8 个趋势!
前端·javascript·vue.js
码银5 小时前
ruoyi的前端(vue)新增的时候给字典设置默认值 但不能正常
前端
凌览5 小时前
别再死磕 Nginx!http-proxy-middleware 低配置起飞
前端·后端