# `.gitignore` 忽略规则
一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以创建一个名为`.gitignore`的文件,列出要忽略的文件的模式。
## 忽略规则
- 所有空行或者以`#`开头的行都会被 Git 忽略。
- 可以使用标准的 `glob` 模式匹配,它会递归地应用在整个工作区中。
- 匹配模式可以以(`/`)开头防止递归。
- 匹配模式可以以(`/`)结尾指定目录。
- *要忽略指定模式以外的文件或目录,可以在模式前加上叹号(`!`)取反。
所谓的 `glob` 模式是指 `shell` 所使用的简化了的正则表达式。
- `*` 匹配零个或多个任意字符;
- `[abc]`匹配任何一个列在方括号中的字符 (这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);
- `?` 只匹配一个任意字符;
- `[α-β]` 表示所有在这两个字符范围内的都可以匹配(比如`[0-9]`表示匹配所有 0 到 9 的数字)。
- `**` 表示匹配任意中间目录,比如`a/**/z`可以匹配`a/z`、`a/b/z`或`a/b/c/z`等。
## 举例
```
# 忽略后缀为 .a 的文件
*.a
# 不忽略所有的 lib.a,即便你在前面忽略了 .a 文件
!lib.a
# 只忽略当前目录下的 TODO 文件,而不忽略子文件夹下的/TODO
/TODO
# 忽略任何目录下名为 build 的文件夹
build/
# 忽略 doc/notes.txt,但不忽略 doc/server/arch.txt
doc/*.txt
# 忽略 doc/ 目录及其所有子目录下的 .pdf 文件
doc/**/*.pdf
```
- 版本控制之Git简介
- Git工作流程
- Git工作区、暂存区、版本库
- Git 指令汇总
- Git 忽略文件规则 .gitignore
- pull request
- HTTP简介
- HTTP - Keep-Alive
- HTTP缓存
- XMLHttpRequest
- Fetch
- 跨域
- HTTP 消息头
- TCP/IP
- TCP首部
- IP首部
- IP 协议
- TCP/IP漫画
- 前端开发规范
- 前端开发规范整理
- 前端未来规划
- HTML思维导图
- CSS思维导图
- 布局
- position,float,display的关系和优先级
- line-height、height、font-size
- 移动端适配
- JS 对象
- JS 原型模式 - 创建对象
- JS 预编译
- 探索JS引擎
- ES