因为以前都把零散的知识都写在 Gist 上,要查找的时候不是很系统化,因此打算挪到 GitBook 上来统一管理,并且 GitBook 写完编译后能够生成静态页面发布到博客上,逼格满满的样子。css
GitBook 是一个基于 Node.js 的命令行工具,下载安装 Node.js,安装完成以后,你可使用下面的命令来检验是否安装成功。html
$ node -v v7.7.1
输入下面的命令来安装 GitBook。node
$ npm install gitbook-cli -g
安装完成以后,你可使用下面的命令来检验是否安装成功。git
$ gitbook -V CLI version: 2.3.2 GitBook version: 3.2.3
更多详情请参照 GitBook 安装文档 来安装 GitBook。github
去 GitBook 官网 下载 GitBook 编辑器;若是是 Mac 用户且安装过 brew cask
的话可使用 brew cask install gitbook-editor
命令行来安装 GitBook 编辑器。web
GitBook 准备工做作好以后,咱们进入一个你要写书的目录,输入以下命令。npm
$ gitbook init
warn: no summary file in this book info: create README.md info: create SUMMARY.md info: initialization is finished
能够看到他会建立 README.md 和 SUMMARY.md 这两个文件,README.md 应该不陌生,就是说明文档,而 SUMMARY.md 其实就是书的章节目录,其默认内容以下所示:json
# Summary
* [Introduction](README.md)
接下来,咱们输入 $ gitbook serve
命令,而后在浏览器地址栏中输入 http://localhost:4000
即可预览书籍。浏览器
效果以下所示:ruby
运行该命令后会在书籍的文件夹中生成一个 _book
文件夹, 里面的内容即为生成的 html 文件,咱们可使用下面命令来生成网页而不开启服务器。
gitbook build
下面咱们来详细介绍下 GitBook 目录结构及相关文件。
GitBook 基本的目录结构以下所示:
. ├── book.json ├── README.md ├── SUMMARY.md ├── chapter-1/ | ├── README.md | └── something.md └── chapter-2/ ├── README.md └── something.md
下面咱们主要来说讲 book.json 和 SUMMARY.md 文件。
该文件主要用来存放配置信息,我先放出个人配置文件。
{ "title": "Blankj's Glory", "author": "Blankj", "description": "select * from learn", "language": "zh-hans", "gitbook": "3.2.3", "styles": { "website": "./styles/website.css" }, "structure": { "readme": "README.md" }, "links": { "sidebar": { "个人狗窝": "https://blankj.com" } }, "plugins": [ "-sharing", "splitter", "expandable-chapters-small", "anchors", "github", "github-buttons", "donate", "sharing-plus", "anchor-navigation-ex", "favicon" ], "pluginsConfig": { "github": { "url": "https://github.com/Blankj" }, "github-buttons": { "buttons": [{ "user": "Blankj", "repo": "glory", "type": "star", "size": "small", "count": true } ] }, "donate": { "alipay": "./source/images/donate.png", "title": "", "button": "赞扬", "alipayText": " " }, "sharing": { "douban": false, "facebook": false, "google": false, "hatenaBookmark": false, "instapaper": false, "line": false, "linkedin": false, "messenger": false, "pocket": false, "qq": false, "qzone": false, "stumbleupon": false, "twitter": false, "viber": false, "vk": false, "weibo": false, "whatsapp": false, "all": [ "google", "facebook", "weibo", "twitter", "qq", "qzone", "linkedin", "pocket" ] }, "anchor-navigation-ex": { "showLevel": false }, "favicon":{ "shortcut": "./source/images/favicon.jpg", "bookmark": "./source/images/favicon.jpg", "appleTouch": "./source/images/apple-touch-icon.jpg",