GitBook 使用教程

GitBook,顾名思义它是一个与书有关的工具。通过 GitBook,你可以只用一些 .md 文件就生成一个电子书网页(我绝对不会告诉你我就是为了它而去学 GitBook 的)或是一本真正的 .epub .mobi 等等格式的电子书。废话不多说,直接开始教程~

1. GitBook 安装

要使用 GitBook 我们得先安装它的命令行工具 gitbook-cli。而安装 gitbook-cli 得先安装 Node.js。没办法,我们先安装吧……

Node.js 官网,点这个 msi 下载安装包然后安装它:

image-20230313131526040

安装完之后 win+r 输入 cmd 打开命令提示符输入 npm --version。如果有弹出信息就说明 Node.js 安装成功了。

image-20230313131831435

然后就可以正式安装 GitBook 了。输入 npm i gitbook-cli -g,安装 gitbook-cli:

image-20230313132025680

完事之后输入 gitbook-cli -V 查看 gitbook-cli 版本号并安装 gitbook 本尊:

image-20230313132856827

等亿会儿,不出意料,它报了一个错:

image-20230313133447463

找到错误中那个 polyfills.js 文件的位置,即上图中画横线的部分。然后打开它,找到 65~67 行,直接全部注释掉(即在前面加上 //),如下:

image-20230313134108066

保存,重新 gitbook -V,应该就能安装成功:

image-20230313175516988

2. GitBook 的基本使用

恭喜!安装成功了~

但这仅仅只是一小步,GitBook 是一个复杂的工具,要不然花这么长一篇文章说它干嘛

找到一只幸运的文件夹,然后如下图所示在此处打开命令提示符:

image-20230313211956744

输入 gitbook init 在该目录初始化一个 gitbook:

image-20230313212219924

不出意外,它又报错了:

image-20230313212726612

网上大部分教程中都是说把 Node.js 换成 12 版,但是 12 版太老了实在是接受不了(T_T)终于,我找到了解决方案(来自博主 @qq_33641175,感谢)。找到你计算机上的这个目录:

image-20230313214453079

然后打开目录下的 init.js,找到第 72 行的 return fs.writeFile(filePath, summary.toText(extension)); 修改为
return summary.toText(extension).then(stx=>{return fs.writeFile(filePath, stx);}),如下:

image-20230313214943106

保存,重新 gitbook init,就可以了~

image-20230313215140267

这时我们会发现出现了两个文件:README.md 与 SUMMARY.md。README.md 是用来写简介的,SUMMARY.md 是用来写目录的。关于 SUMMARY.md 我们会在第 3 节具体说明。现在先把目光放在 README.md 上。

打开 README.md(我使用的是 Typora),在里面随便写些简介:

image-20230314124220594

刚才那个命令行应该没关吧?如果关了就再启动一次。输入 gitbook serve,在跳出的这个界面把两个都勾起来然后点确定:

image-20230314124531585

然后会跳出一个 URL(通常是 localhost:4000),你可以在这里预览你的电子书(按下 Ctrl + C):

image-20230314124640732

(关于里面的内容怎么切换成中文,第 4 节会详细说。)

你可能会在文件夹中发现一个新的文件夹叫做 _books,里面存放着一些 HTML CSS JS 等静态文件。这些静态文件我们可以放在服务器上或是 GitHub Pages 上,这样别人就可以通过访问你的服务器或 GitHub Pages 来看你的电子书。

(如果你想生成真正的电子书,请参阅最后一章)

如果我们只想生成静态文件,不想开启预览怎么办呢?我们可以使用 gitbook build 命令,它只生成静态页面,不开启预览~~(这不废话)~~。

3. SUMMARY.md

这一小节我们要来聊一聊文章目录 SUMMARY.md。首先我们需要知道 MarkDown 语法里面的锚链接。它的结构是 [](),中括号里写链接的文字,小括号里写链接的地址。比如 [目录](SUMMARY.md) 就是一个显示为目录的链接,SUMMARY.md 是链接的地址。你点击这个链接,它就会帮你跳转至 SUMMARY.md。

让我们在 SUMMARY.md 中试一试。书写目录时使用无序列表,快捷键 Ctrl + Shift + ]。如下:

image-20230314215433031

保存,重新 gitbook serve,你会发现 something different:

image-20230314215844016

SUMMARY.md 还可以创建复杂一些的目录结构,比如 第一章 第一节之类的子目录结构。首先我们创建几个 md,然后把它们放进不同的文件夹内(其中各部分的 README.md 为该章的引言,可以要也可以不要):

image-20230315124109238

image-20230315124719489

image-20230315124816385

同时指向它们的锚链接格式也要有些变化,需要加上目录名,比如 Chapter 1/README.md。

然后更改 SUMMARY.md。如果你需要书写二级目录(比如 Chapter 1 下的各篇小 md 的目录),你可以按下 Tab 键使这个无序列表变成二级的。如下:

image-20230315125952441

重新 gitbook serve:

image-20230315130309385

SUMMARY.md 中还有一个语法:分割线 —。它可以把我们的目录上下分成不同的部分。实验一下:

image-20230315130607154

重新 gitbook serve:

image-20230315130707182

4. book.json

这一小节要说的文件是 book.json。它是我们电子书的配置文件。gitbook 初始化的时候虽然没有为我们自动生成,但是我们可以自己创建。在与 SUMMARY.md 同级的目录中新建 book.json,然后打开它:

image-20230315131019564

以下是 book.json 的常用的一些功能:

{
    "title": "Easy Algorithms",
    "author": "copcin",
    "description": "阿巴阿巴",
    "language": "zh-hans",
    "gitbook": "3.2.3",
    "links": {
        "sidebar": {
            "GitHub": "xxx"
        }
    }
}

对每一个选项做一下说明:

title:书名

author:作者

description:对书的简单描述

language:zh-hans 代表简体中文。有了这个选项你就可以把 GitBook 页面切换成中文。

gitbook:GitBook 版本。通常为 3.2.3。

links.sidebar:侧边栏的一些链接。比如 “GitHub”: “xxx” 就代表一个名字为 GitHub 的指向 xxx 的链接。

保存,重新 gitbook serve:

image-20230315132837961

有没有发现什么不一样~

5. GitBook 插件管理

GitBook 支持使用一些插件来拓展 GitBook 的功能。所以这小节我们讲讲插件的管理。

首先是插件的下载,首先你需要在 book.json 中添加你想要的插件名,比如这里我添加了一个 github(在网站的右上角显示一个 GitHub Logo,点击它自动跳转你的 GitHub 页面,需要自己设置):

image-20230315172117489

然后命令行输入 gitbook install 安装这个插件:

image-20230315134122375

安装要费些时间。安装完之后在 book.json 中配置 github 插件:

image-20230315172144196

gitbook serve,你会发现右上角多了一个 GitHub Logo,点一下会跳转你刚刚设置的那个链接~

image-20230315172439381

GitBook 插件绝大部分都在 NPM 上。所以你可以去 NPM 官网 npmjs.com 搜索 gitbook-plugin,会弹出很多插件,如果需要某一个插件 gitbook-plugin- 后面的内容就是插件名,安装方法和刚刚介绍的 github 一样。

image-20230315172838170

除此之外 GitBook 自带了一些插件:livereload,highlight,lunr,search,sharing,font-settings,themedefault。如果我们想禁用一个插件,就在 plugins 一栏的数组中加上 -插件名。比如我想禁用用于分享的 sharing:

image-20230315173323962

保存,重新 serve,你会发现右上角推特,Facebook 的那几个分享 Logo 已经没了:

image-20230315173440687

6. 输出你的电子书

最后就是大家最为关心的电子书输出问题了。在输出之前,我们要先安装一个电子书转换的软件:Calibre。打开 https://calibre-ebook.com/download,点击 Windows:

image-20230315174743184

然后下载。Win 10 及以上下载红箭头。Win 8 及 Win 8.1 下载蓝箭头。Win 7 或 Vista 下载绿箭头。我下载的是蓝箭头:

image-20230315174925885

点击箭头指向的链接开始下载:

image-20230315175031265

安装过程一路 Next,这里不再赘述。安装完进行一些初始化配置即可关闭 Calibre。

然后就简单了,重启命令行(这一步一定要重启,要不然报错)你想输出成什么格式你就输入 gitbook 格式名。比如你想输出成 epub 就 gitbook epub。GitBook 会帮你生成静态文件,然后转换为你的格式。比如我转换一个 epub:

image-20230315180037629

然后你去你电子书的目录下看一看,应该能够看见一个 .epub 类型的文件。这就是你的电子书。GitBook 支持的格式有 epub mobi 和 pdf。

你还可以使用 Calibre 对电子书进行进一步的设置,比如给书加上封面。打开 Calibre,点击添加书籍,选择你刚刚生成的 .epub:

image-20230315211047334

选择刚刚添加的书,点击“编辑元数据”;

image-20230315211431318

这个页面可以更改书的很多选项,包括封面。可以点击“浏览”导入图片设置为封面。点确定,你的书就大功告成了~

alibre 对电子书进行进一步的设置,比如给书加上封面。打开 Calibre,点击添加书籍,选择你刚刚生成的 .epub:

[外链图片转存中…(img-SkDJZtf5-1678888484423)]

选择刚刚添加的书,点击“编辑元数据”;

[外链图片转存中…(img-UPtvZ2kh-1678888484424)]

这个页面可以更改书的很多选项,包括封面。可以点击“浏览”导入图片设置为封面。点确定,你的书就大功告成了~

Enjoy 你的 GitBook 之旅吧~

  • 5
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值