不清楚的 .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才能识别.

有趣 🌾

相关推荐
人工智能训练4 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪5 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
pas1368 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠8 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
珑墨9 小时前
【Turbo】使用介绍
前端
军军君019 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
打小就很皮...10 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
wuhen_n11 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon11 小时前
理解vue中的ref
前端·javascript·vue.js
大卫小东(Sheldon)11 小时前
GIM 2.0 发布:真正让 AI 提交消息可定制、可控、可项目级优化
git·rust·gim