怎么用 git 写书

发布于 2025-03-08 03:05:01 字数 4237 浏览 2 评论 0

安装环境

第一步 安装 node npm

先检测自己电脑是否安装了 node npm

    # 查看 node 版本
    node -v
     
    # 查看 npm 版本
    npm -v
    复制代码

如果成功打印出版本号,说明你本地具备了 node 的运行环境(安装 node 默认安装 npm),而如果没有或报错,则你需要去 node 官网进行 node 的下载及安装,如图:

左边的版本是推荐安装的稳定版本,也就是目前已经被正式列入标准的版本,而右边的版本是当前最新的版本,该版本包含了一些新的特性,还未被完全列入标准,可能以后会有所变动。这里建议大家安装最新的 node 稳定版进行开发。

第二步 全局安装 gitbook-cli

建议使用 npm 淘宝源:

npm config set registry https://registry.npm.taobao.org/

然后安装 gitbook -cli

npm i -g gitbook-cli

第三部 初始化电子书

# 创建一个目录,进入
mkdir gitbook-demo
cd gitbook-demo
 
# 初始化电子书目录
gitbook init 
 
# 编译电子书
gitbook serve 
复制代码

说明一下:

init 以后,目录里会有这两个文件 README.mdSUMMARY.mdREADME.md 是对电子书的简单介绍, SUMMARY.md 是电子书的目录结构。

目录结构长这样:

* [电子书名称](README.md)
* [第一章](chapter1/README.md)
    * [xxxx](chapter1/section1.1.md)
    * [xxxx](chapter1/section1.2.md)
* [第二章](chapter2/README.md)
    * [xxxx](chapter2/section2.1.md)
    * [xxxx](chapter2/section2.2.md)
复制代码

编写 SUMMARY.md ,执行 gitbook init 生成目录结构文件,然后编写各个文件夹中生成的文件。

最后 gitbook serve。

gitbook serve 命令实际上会首先调用 gitbook build 编译书籍,完成以后会打开一个 web 服务器,监听在本地的 4000 端口。

如果当前书籍写完了,想要发布到自己的网站的话,也可以使用命令输出成 html 文件使用

gitbook build [书籍路径] [输出路径]

最后搭配 git 一起使用时,只需要在书籍根目录下执行

git init

创建一个 git 仓库,然后就愉快的拉取-书写-提交循环即可了。

别忘了在提交的时候忽略掉 module 文件夹,不然每次提交拉取的时候会很痛苦....

图形化编辑管理工具

用一个图形化编辑管理工具,方便我们实时编辑查看内容,这里推荐用 VScode,又可以编辑 Markdown,又可以用 git,又可以分屏看效果。别忘了在提交的时候忽略掉 module 文件夹,不然每次提交拉取的时候会很痛苦....
处理 VScode 中 md 文件的乱码问题,可以手动生成 md 文件。不用系统自动生成,这样可以避免乱码

小拓展

你可以将电子书提交到 github,在托管电子书的仓库建一个 gh-pages 分支,将本地编译好的电子书文件(项目根目录下的 _book 目录里的文件 )上传到这个分支,然后就可以使用这个网址访问 http://yourUserName.github.io/bookName

当然也可以发布到 gitbook,然而这个网站访问有点慢。

gitbook 目录折叠

插件名称:toggle-chapters

效果:默认只在目录导航中显示章的标题,而不会显示小节的标题,点击每一章或者每一节会显示当前章或节的子目录,如果有的话,但是同时会收起其它之前展开的章节。关于更多的 gitbook 插件,读者可以参考插件网站。在根目录(即与 SUMMARY.md 同级的目录) 下的配置文件 book.json(如果没有则新建) 中添加插件配置,如图


配置完成后,可按照一下步骤进行:

cdgitbook根目录cd gitbook 根目录cdgitbook根目录 npm install gitbook-plugin-toggle-chapters ​ (此时 gitbook 的根目录下的 node_modules 文件夹中已经有了该插件了)

gitbook build gitbook build gitbook build gitbook serve

访问 http://localhost:4000 看你的插件是否已经生效。

图片使用

可以上传到 github,然后将 URL 中 blob 替换为 raw,或者可以用博客园的此编辑器,添加图片后发布出来,然后再编辑的时候,就可以看到图片的链接,直接复制到本地编辑器就可以。网页浏览复制图片 URL,将 URL 中 blob 替换为 raw

GitBook 源文件发布到 gh-pages

复制_book 文件下的所有文件,切换到 gh-pages 分支,然后复制到这个目录下,然后推送、

以下代码可以创建个 publish.sh 的脚本文件,放到 git 仓库外执行,自动同步到 gh-pages 分支(记住每次执行脚本的时候,要把打开的文件全部关闭掉,不然被占用了,git 会出现错误,还得用版本回退)

cd /f/Leo/StudyNotes  &&\
git checkout master &&\
gitbook init &&\
gitbook build &&\
git add . &&\
git commit -m 'update gitbook' &&\
git push origin master &&\
git checkout gh-pages &&\
rm -rf * &&\
git checkout master -- _book &&\
mv _book/* ./ &&\
rm -rf _book &&\
rm -rf publish.sh &&\
git add . &&\
git commit -m 'publish gh-pages' &&\
git push origin gh-pages &&\
git checkout master

版本回退并强制推送到

使用 git log 命令历史版本记录回退版本

git reset --hard f6a7c803a6931a9eca011d4e097389e0845cbe49

推送到远程

git push -f -u origin master

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84965 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文