# GitBook使用

## 软件下载

前往 [ GitBook 官网 ](https://www.gitbook.com/editor/windows)下载 GitBook 安装包。

## 软件安装

执行下载好的 GitBook 安装包即可安装 GitBook。

## 创建书籍

1. 打开安装好的 GitBook。
2. 选择 New Book。  
   ![创建书籍1](img/create_book_1.png "创建书籍")
3. 输入 Book 的名称,选择 Create Book。  
   ![创建书籍2](img/create_book_2.png "创建书籍")
4. 创建成功以后视图中出现刚创建的图书,点击就可以打开刚创建的图书了。  
   ![创建书籍3](img/create_book_3.png "创建书籍")

## 下载书籍

1. 首先从 GitLab 库中 clone 已存在的某书籍。
2. 选择 import 导入该书籍的文件夹。  
   ![导入书籍1](img/import_book_1.png "导入书籍")
   ![导入书籍2](img/import_book_2.png "导入书籍")

## 同步书籍

当书籍内容发生更改后,可以通过点击 Sync 进行同步。  
![同步书籍](img/sync_book.png "同步书籍")

## GitBook 语法

* GitBook 采用的是 MarkDown 语法, Markdown 的语法全由一些符号所组成。  
* 而 Markdown 是 HTML 的一个子集,所以 Markdown 完全兼容 Html 的语法,也就意味着在文本中的任何位置使用 html 标签都是可以的。  
* 但在 html 标签中使用 Markdown 语法则无法被识别。  
* 所以在文本中不建议使用 html 语法。

### 目录

* [横线](#横线)
* [标题](#标题)
* [文本](#文本)
  * [普通文本](#普通文本)
  * [单行文本](#单行文本)
  * [文本块](#文本块)
  * [文字换行](#文字换行)
  * [斜体、粗体、删除线](#斜体、粗体、删除线)
  * [数学符号](#数学符号)
* [代码](#代码)
  * [短代码](#短代码)
  * [代码块](#代码块)
  * [代码高亮](#代码高亮)
* [链接](#链接)
  * [基本链接](#基本链接)
  * [文字链接](#文字链接)
  * [本地仓库链接](#本地仓库链接)
  * [页内锚点](#页内锚点)
* [图片](#图片)
  * [显示图片](#显示图片)
  * [图片链接](#图片链接)
* [列表](#列表)
  * [无序列表](#无序列表)
    * [多级无序列表](#多级无序列表)
  * [有序列表](#有序列表)
    * [有序列表自动排序](#有序列表自动排序)
    * [多级有序列表](#多级有序列表)
  * [复选框列表](#复选框列表)
* [表格](#表格)
* [表情](#表情)

### 横线

`***、---、___` 可以显示横线效果,效果如下:

---

---

---

### 标题

```
# H1
## H2
### H3
#### H4
##### H5
###### H6
```

对于 H1,H2 也可以使用如下语法:

```
H1
======

H2
------
```

### 文本

#### 普通文本

只是一行普通文本。

#### 单行文本

在一行的开头添加4个空格即可。

```
这是一行单行文本。
```

#### 文本块

在连续几行的文本开头4个空格。

```
这是第一行。
这是第二行。
这是第三行。
```

#### 文字换行

直接回车并不能换行:  
1. 在上一行文本最后添加两个空格。  
2. 两行文本直接加一个空行,这样行距更大。  
3. 使用 html 标签中的 `<p>` 标签也可以达到换行效果。

#### 斜体、粗体、删除线

| 语法 | 效果 |
| --- | --- |
| `*斜体1*` | _斜体1_ |
| `_斜体2_` | _斜体2_ |
| `**粗体1**` | **粗体1** |
| `__粗体2__` | **粗体2** |
| `这是一个 ~~删除线~~` | 这是一个 ~~删除线~~ |
| `***斜粗体1***` | _**斜粗体1**_ |
| `___斜粗体2___` | _**斜粗体2**_ |
| `***~~斜粗体删除线1~~***` | ~~_**斜粗体删除线1**_~~ |
| `~~***斜粗体删除线2***~~` | ~~_**斜粗体删除线2**_~~ |

#### 数学符号

使用四个 `$` 将要写的符号包含起来。

$$math$$

### 代码

#### 短代码

使用 ``` `` 将短的代码包起来。

#### 代码块

使用 ``````` ```` 在代码块前后。

```
这是一段代码块。
这是一段代码块。
```

#### 代码高亮

在``````` ````后面加上编程语言的名字,另起一行开始写代码,最后一行再加``````` ````。

```java
public static void main(String[] args){} //Java
```

```c
int main(int argc, char *argv[]) //C
```

```bash
echo "hello GitHub" #Bash
```

```javascript
document.getElementById("myH1").innerHTML="Welcome to my Homepage"; //javascipt
```

```cpp
string &operator+(const string& A,const string& B) //cpp
```

```javascript
var s = "JavaScript syntax highlighting";
alert(s);
```

```python
def function():
    #indenting works just fine in the fenced code block
    s = "Python syntax highlighting"
    print s
```

```ruby
require 'redcarpet'
markdown = Redcarpet.new("Hello World!")
puts markdown.to_html
```

**注:** _编程语言必须为英文小写字母,否则在 GitLab 上可能无法显示效果_

### 链接

#### 基本链接

GitBook 几乎可以自动链接任何URL,只要直接复制链接到文本中即可。  
[http://www.google.com](http://www.google.com)

#### 文字链接

| 样式 | 语法 | 效果 |
| --- | --- | --- |
| 内嵌式链接 | `[这是一个内嵌式链接](https://www.google.com "这是一个内嵌式lianjie")` | [这是一个内嵌式链接](https://www.google.com "这是一个内嵌式lianjie") |
| 引用式链接 | `[这是一个引用式链接][text]` | \[这是一个引用式链接\]\[text\] |
| URL 标识符 | `[text]: https://www.google.com "这是 URL 标识符"` | \[\[text\]: [https://www.google.com](https://www.google.com) "这是 URL 标识符" |

**注:** _一般把全文所有的 URL 标识符统一放在文章末尾_

#### 本地仓库链接

| 语法 | 效果 |
| --- | --- |
| `[这将指向 SUMMARY.md 文件](/SUMMARY.md)` | [这将指向 SUMMARY.md 文件](/SUMMARY.md) |
| `[这将指向 根目录](./)` | [这将指向根目录](./) |

#### 页内锚点

| 语法 | 效果 |
| --- | --- |
| `[回到顶部](#软件下载)` | [回到顶部](#软件下载) |

### 图片

#### 显示图片

基本格式:

```
![alt](url title)
```

alt 和 title 即对应 HTML 中的 alt 和 title 属性(都可省略):

* alt 表示图片显示失败时的替换文本。
* title 表示鼠标悬停在图片时的显示文本(注意这里要加引号)。
* url 即图片的 url 地址,如果引用本仓库中的图片,直接使用相对路径就可了。

![示例图片](img/logo.png "示例图片")

#### 图片链接

给图片加链接的本质是混合图片显示语法和普通的链接语法。普通的链接中`[ ]`内部是链接要显示的文本,而图片链接`[ ]`里面则是要显示的图片。

| 语法 | 效果 |
| --- | :---: |
| `[![hand-logo]](http://app.hand-china.com/hrms/)` | [![](/img/logo.png "点击图片进入hand")](http://app.hand-china.com/hrms/) |

`[hand-logo]:/img/logo.png "点击图片进入hand"`

### 列表

#### 无序列表

使用 `*` 或者 `-`

```
* 这是一个无序列表
- 这是一个无序列表
```

* 这是一个无序列表
* 这是一个无序列表

##### 多级无序列表

每一级列表添加一个 `TAB` 用于区分。

* 编程语言
  * 脚本语言
    * Python

#### 有序列表

在数字后面加 `.` ,再加一个空格。不过看起来起来可能不够明显。

这是一个有序列表:  
1. 有序列表1;  
2. 有序列表2;  
3. 有序列表3。

##### 有序列表自动排序

也可以在第一行指定 `1.`,而接下来的几行用星号 `*` (或者继续用数字 `1.` )就可以了,它会自动显示成2、3、4……。

```
这是一个有序列表:
1. 有序列表1;
* 有序列表2;
1. 有序列表3。
```

这是一个有序列表:  
1. 有序列表1;

* 有序列表2;
* 有序列表3。

##### 多级有序列表

和多级无序列表一样,添加一个 `TAB` 用于区分。但最多之恩能够显示3级。

```
1. 这是一级的有序列表,数字1还是1
  2. 这是二级的有序列表,阿拉伯数字在显示的时候变成了罗马数字
    3. 这是三级的有序列表,数字在显示的时候变成了英文字母
      4. 四级的有序列表显示效果,就不再变化了,依旧是英文字母
```

1. 这是一级的有序列表,数字1还是1
   1. 这是二级的有序列表,阿拉伯数字在显示的时候变成了罗马数字
      1. 这是三级的有序列表,数字在显示的时候变成了英文字母
      2. 四级的有序列表显示效果,就不再变化了,依旧是英文字母

#### 复选框列表

* [x] 需求分析
* [x] 系统设计
* [x] 详细设计
* [ ] 编码
* [ ] 测试
* [ ] 交付

**注:** _复选框列表在 GitBook 中无法有效显示,但是在 GitLab 中可以显示。_

### 表格

表格并不是 Mrakdown 的核心,如果要使用的话,可以使用如下语法:

```
| header 1 | header 2 |
| -------- | -------- |
| cell 1   | cell 2   |
| cell 3   | cell 4   |
```

生成后的结果如下:

| header 1 | header 2 |
| --- | --- |
| cell 1 | cell 2 |
| cell 3 | cell 4 |

可以使用 `---` 和 `:` 来对齐表格

```
| 左对齐 | 居中 | 右对齐 |
| :----------- | :------: | ------------: |
| Cell 1       | Cell 2   | Cell 3        |
| Cell 7       | Cell 8   | Cell 9        |
```

效果如下:

| 左对齐 | 居中 | 右对齐 |
| :--- | :---: | ---: |
| Cell 1 | Cell 2 | Cell 3 |
| Cell 7 | Cell 8 | Cell 9 |

**注意:**  `---`_的数目是最好以上述样式为准,否则 Gitlab 上可能无法显示。_

### 表情

Github的Markdown语法支持添加emoji表情,输入不同的符号码(两个冒号包围的字符)可以显示出不同的表情。  
比如 `:blush:` ,可以显示 :blush:。  
具体每一个表情的符号码,可以查询GitHub的官方网页 [http://www.emoji-cheat-sheet.com](http://www.emoji-cheat-sheet.com) 。

**注:** _ emoji 表情在 gitbook 上可能无法显示。_