Gitbook
作者:高天阳
邮箱:13683265113@163.com
历史、现状和发展
GitBook创建于2014年中期,致力于为文档,数字书写和出版创建一个现代化的简单解决方案。
我们已经开始构建一个开源的格式。哲学是简单到优雅的地步,消除内容创作者的分心和关注,使他们可以自由地写作。 从那时起,我们已经长大了帮助超过25万人一起工作到写作150,000册图书投放到20M的游客每月。
简介
GitBook 是一个基于 Node.js 的命令行工具,可使用 Github/Git 和 Markdown 来制作精美的电子书。
GitBook可以把你的书本生成为静态网站以及PDF、ePub(苹果和google的设备支持这种格式)、Mobi(kindle支持的格式)格式的电子书。
个人观点:这类应该是未来书籍出版的方向
特点
更新简单,使用Git(分布式版本控制系统)或者web编辑器发布和更新你的电子书是很容易的;
版本管理,Gitbook是以GIT-scm为基础的.一句简单的
git push
代码就可以发布一个新版本;Github,通过Gitbook可以在Gihub上同步更新你的电子书;
数据分析,记录PV和下载,提供强大的
洞察力?
;编辑,使用web编辑器编辑你的内容,更新之前可以预览内容;
个性化品牌,个人主页和自定义域名;
合作,结构化你的流程,安全的访问控制
安装和使用
安装
安装GitBook
gitbook的安装非常简单,详细指南可以参考 gitbook 文档。
这里的安装只需要一步就能完成!
需要注意的是:用户首先需要安装 nodejs,以便能够使用 npm 来安装 gitbook。
安装GitBook脚手架
windows下安装GitBook脚手架
输入命令,全局安装gitbook。
在CMD窗口中输入
mkdir mybook 创建文件夹
切换到目录下.
切换文件夹后在当前文件目录下的在窗口中输入如下命令
Mac下安装GitBook脚手架
GitBook 是一个基于 Node.js 的命令行工具;安装gitbook-cli需要首先安装nodeJS,安装gitbook-cli:
配置
使用
配置
title
author
description
language
links
styles
plugins
pluginsConfig
gitbook插件
Disqus
Search Pro
Advanced Emoji
Github
Ace Plugin
Emphasize
KaTex
Include Codeblock
Splitter
Mermaid
Sharing
Tbfed-pagefooter
Toggle Chapters
Sectionx
Codeblock-filename
ga
baidu
gitbook输出方式
静态站点:GitBook默认输出该种格式
PDF:需要安装gitbook-pdf依赖
eBook:需要安装ebook-convert
gitbook插件
示例
GitBook章节和子章节
在学习使用之前,我们首先需要了解一下SUMMARY.md
是干什么的。GitBook使用文件 SUMMARY.md
来定义书本的章节和子章节的结构。 文件 SUMMARY.md
被用来生成书本内容的预览表。
SUMMARY.md
的格式是一个简单的链接列表,链接的名字是章节的名字,链接的指向是章节文件的路径。
子章节被简单的定义为一个内嵌于父章节的列表。
简单实例:
gitbook 的基本用法非常简单,基本上就只有两步:
使用
gitbook init
初始化书籍目录使用
gitbook serve
预览书籍使用
gitbook build
编译书籍
下面将结合一个非常简单的实例,来介绍 gitbook 的基本用法。
GitBook初始化
首先,创建如下目录结构:
README.md 和 SUMMARY.md 是两个必须文件
README.md 文件内容作为创建的gitbook的简介;
SUMMARY.md 文件内容为创建的gitbook的目录信息;
这样我们就会在自己的电脑上创建对好应的md文件;
GitBook预览
当你在自己的电脑上编辑好图书之后,你可以使用Gitbook的命令行进行本地预览:
git build .
默认生成了_book文件夹存储生成的html文件,可以使用:
在线协作文档
gitbook可以帮助我们团队在线编写gitbook,协作编辑文档。
tips: 首先要有git账号:
接下来登录gitbook,使用git账号登录:
进入主页选择点击create book,进入创建书籍页面,选择创建github类型书籍:
点击图中2所指按钮,进入github页面;在github上安装gitbook;并创建gitbook相关创库:
接下里回到gitbook网站,新建书籍,选择github出现填写title等,选择刚才创建的仓库;然后点击Create book
按钮,生成新的书籍;
这样我们就可以通过在github上上传我们创建的book,然后显示在gitbook上;
按照github上指示将本地创建的book上传到对应的仓库;
在gitbook上刷新书籍我们就能看到这本书书籍了;在setting里通过添加成员并设置权限就可以实现多成员共同维护这本书籍了~
最佳实践
gitbook启动的web 服务默认监听4000端口,而重启监控进程默认监听35729端口。一般这样可以启动一个电子书web服务:
本地就可以这样来访问: http://localhost:4000 。
如果要启动另一部电子书服务的话, 就需要同时修改web端口和监控进程端口, 类似这样:
否则会报如下错误:
或者如下错误:
最后, 贴上gitbook的官方用法说明:
处理方法
查看本机用户名密码获取方式
此时应显示为osxkeychain
钥匙串 如果不是需编辑.gitconfig
文件的[helper]
Mac系统打开钥匙串访问,查看到对应gitbook的秘钥(你会发现此秘钥不是你自己的账号密码),并删除它。
再次提交代码,会提示你输入用户名密码。输入后成功提交。
gitbook serve报错
windows系统gitbook serve时报错找不到lunr.min.js
处理方法
按下面顺序执行命令
GitBook生成pdf
安装calibre插件
玩过kindle的都知道,calibre是一款非常方便的开源电子书转换软件。在这里,我们也是用到ebook-convert这个插件。
首先在calibre官网下载插件,插件下载地址。下载适合自己系统的版本。
下载到电脑之后我做了很多尝试,刚下载之后我兴冲冲的去使用gitbook pdf .mypdf.pdf
指令,结果发现提示ebook-convert未安装。
这里我通过咨询了一些大神,在这个过程中他们给了我很大的帮助。也查看了很多教程,所有教程中都说了两个问题
将安装的calibre放在系统应用中,然后将app添加到path中。
这个说实话我也没怎么看懂,但是下面我会详细的说这一步如何操作。
执行一个命令
以上两部我都做了,最终也成功的将Gitbook导出了PDF,但具体是哪一步起了作用,我估计是第二步,不过在教程中我优先推荐使用第二步。 第二步遇到的坑是,在网上我们找到的教程只是输入ln -s /Applications/calibre.app/Contents/MacOS/ebook-convert /usr/local/bin
, 但是执行多次都没有结果,WIN系统执行这步可能已经正确了。因为Mac环境权限的原因,这里加入sudo重新执行即可。
执行完成之后,重新进入书籍目录。
执行完以上代码,进入书籍目录,即可看到已经转换完成的PDF了。大功告成!
同类技术对比(列表)
GitBook
喜欢:
多人协作及团队支持
基于GIT的版本历史和还原
在线写作/离线写作
关注、分享和收藏功能
文档导入和导出支持
支持发布在github博客系统上,别人可以来fork可以来帮你纠错,给你发pull request。
独立的应用程序。
这是一家书店。
发布到大型商店。
不喜欢:
不翻墙的时候打开会比较慢。
丑陋的MSWord-like排版。
根本没有“社交协作”,似乎只是由Git支持。不确定应用程序是否支持小规模协作(双人作者),或者您必须自己处理Git复杂性。
似乎技术导向。没有小说类别。
kanCloud——专注于文档在线创作、协作、分享和托管
看云的发布版本和编辑版本是分离的,而且看云对技术文档做了一些优化,并且支持 API 文档(包括在线调试)。 最新更新支持插入视频。另外一个在国内定价收费也方便。
喜欢:
全新体验的Markdown编辑器,让你的创作更有灵感
响应式设计的阅读方式
数学公式和目录导航
支持插入流程图/时序图
创建私有文档以及文档权限控制
在线写作/离线写作
基于GIT的版本历史和还原
多人协作及团队支持
文档更新动态和评论通知
关注、分享和收藏功能
文档导入和导出支持
域名绑定/导航自定义
支持文档统计功能
支持插入优酷视频
文档打赏和付费阅读
离线写作客户端
阅读客户端(支持安卓和IOS)
Leanpub——Publish Early, Publish Often
喜欢:
精益出版。
作者与读者的互动非常棒。
他们的PDF输出是美丽的。
这是一个书店(90%版税!)与社交网络方面。
创建捆绑包,与其他作者分享版税等非常容易。真的很棒的功能。
营销工具真棒。与Google Analytics(分析)整合
不喜欢:
我无法下载他们的工具链(但在“Markdown to Ebook”[0]之后,本地工作流程有点可重现)
不依赖于Git,但在Dropbox中。没有适当的版本控制。
没有合作。
不发布到主要书店(但允许你这样做)。
penflip——在线文本编辑工具
Penflip似乎更适合你的想法(注意:现在我知道它为什么适合你的想法),像GitHub一样合作。
喜欢:
多人协作及团队支持
不喜欢:
与书店没有整合。
这不是一个书店,你不能轻易发现书籍。
看起来更像是一个使用FSF意义上的“免费”的“免费书籍”平台。
很难找到一本完整的书来窥探,但是输出看起来和GitBook一样丑陋。AFAIK他们让你自定义输出,
但似乎排版不是LaTeX-like,怀疑它不可以胜任。默认是非常重要的,它应该是美丽的开箱即用。
参考资料
Last updated