欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

使用 GitBook 编写文档和生成电子书(静态网页

最编程 2024-07-17 20:59:13
...

本文目录


  • 1、Gitbook 简介
  • 2、Gitbook 环境配置

nodejs高于6.0版本要安装gitbook3.2.3版本以上,否则会有问题


1、Gitbook 简介


1.1 Gitbook


  • GitBook 是一个基于 Node.js 开发的命令行工具,使用它可以很方便的管理电子书,GitBook 是目前最流行的开源书籍写作方案。
  • 使用 GitBook 可以让创作者专注写作,*的挥洒,不必太多的关心内容排版、发布和版本管理等问题。
  • 除了通过 GitBook 命令行管理电子书外,还可以在线或者使用桌面编辑器 Gitbook Editor 来编写和管理电子书。
  • 对于新手来说,推荐使用 Gitbook Editor 来编写和管理电子书,因为它集成了 GitBook 命令、Markdown 编器和 Git 的功能,内容通过 Git 可与 gitbook.com / Gitlab / GitHub 同步,方便版本管理和团队协作。
  • 可对于程序员或熟悉 Git 和 Markdown 的人,更推荐使用 GitBook 命令行 + Typora + SourceTree 来编写和管理电子书。使用专业工具做专业的事,比 Gitbook Editor 高效很多。
  • GitBook 是开源的。


1.2 GitBook 功能


  • 支持 Markdown 或 AsciiDoc 语法。
  • 可导出静态站点或电子书(PDF、epub、mobi)。
  • 支持多语言。
  • 可设置封面。
  • 支持变量、模板和模板继承。
  • 有丰富的插件。


1.3 GitBook 的工具组合


  • Node.js:为了使用 npm 安装 GitBook,一定要先安装 Node.js。
  • GitBook 命令:基于 Node.js 开发的命令行工具,用于创建和管理电子书。
  • Markdown:GitBook 使用 Markdown 来写作,作者再也不用担心排版了。
  • Git:GitBook 使用 Git 管理写作内容,方便多人协作和版本管理。
  • Github/Gitlab:跟代码一样,写作的内容可以托管在 Github 或 Gitlab 中。
  • gitbook.com:用于在线编写、发布和托管电子书的网站。


1.4 GitBook 的使用场景


  • 搭建公司内部的文档平台,用于公司内部的资料共享。
  • 发表开源的电子书,用于在互联网上共享自己的知识,普惠大众。

2、Gitbook 环境配置


2.1 安装 Node.js


  • 因为 GitBook 是使用 Node.js 开发的,需要通过 Node.js 包管理工具 NPM 安装,所以在开始之前要先把 Node.js 安装好。

2.2 安装 GitBook


  • 使用 NPM 安装 GitBook 的命令行工具。
$ sudo npm install gitbook-cli -g
  • 安装完成后查看 GitBook 的版本。
$ gitbook --version
  • 更新 GitBook 命令。
$ npm update gitbook-cli -g
  • 卸载 GitBook 命令。
$ sudo npm uninstall gitbook-cli -g
  • 注意:
  • 本例中使用的是全局安装 GitBook 命令,还有一种安装方式是本地安装,两种方式有什么不同呢?
  • 本地安装:安装包会被下载到当前所在目录,因此只能在当前目录下使用。
  • 全局安装:安装包会被下载到到特定的系统目录下,安装包能够在所有目录下使用。
  • 例如,查看 macOS 下全局安装被安装到了哪里?
$ which gitbook
/usr/local/bin/gitbook
  • GitBook 被安装到了 /usr/local/bin/ 目录下,因此可以全局使用。


2.3 快速开始 GitBook


  • 1)初始化 GitBook
# 创建 mygitbook 文件夹,并切换到这个文件夹下面
$ mkdir mygitbook && cd mygitbook
# 初始化 gitbook 工作目录,创建必要的文件
$ gitbook init
warn: no summary file in this book
info: create README.md
info: create SUMMARY.md
info: initialization is finished
  • 然后会初始化 GitBook 目录,创建两个 md 格式的文件 README.md 和 SUMMARY.md
  • README.md - 项目的介绍都写在这个文件里。
  • SUMMARY.md - GitBook 的目录结构在这里配置。
  • 2)定义目录结构
  • 两种方法
  • 在 SUMMARY.md 文件中定义目录结构有两种方法。
  • 方法 ➊. 先定义好目录结构,通过 gitbook init 自动生成目录结构对应的文件夹和 Markdown 文件。
  • 方法 ➋. 先创建好文件夹和 Markdown 文件再来编辑目录结构。
  • SUMMARY.md
  • SUMMARY.md 的目录结构长什么样?看下面:
# Summary
* [项目简介](README.md)
* [快速开始](docs/快速开始.md)
 * [环境搭建](docs/环境搭建.md)
 * [简单使用](docs/简单使用.md)
* [学入学习](docs/深入学习)
  • 这个目录建好以后在根目录下执行命令:
$ gitbook init
  • 那些没有的目录和文件都会被创建:
info: create docs/快速开始.md
info: create docs/环境搭建.md
info: create docs/简单使用.md
info: create docs/深入学习.md
info: create SUMMARY.md
info: initialization is finished
  • gitbook init 只支持生成两级目录。
  • 3)启动服务
  • 在根目录执行命令:
$ gitbook serve
  • 结果:
Live reload server started on port: 35729
Press CTRL+C to quit ...
info: 7 plugins are installed
info: loading plugin "livereload"... OK
info: loading plugin "highlight"... OK
info: loading plugin "search"... OK
info: loading plugin "lunr"... OK
info: loading plugin "sharing"... OK
info: loading plugin "fontsettings"... OK
info: loading plugin "theme-default"... OK
info: found 5 pages
info: found 0 asset files
info: >> generation finished with success in 1.9s !
Starting server ...
Serving book on http://localhost:4000       # 注意浏览地址
  • 执行 gitbook serve 命令后,会先编译书籍 gitbook build,如果没有问题会打开一个 Web 服务器,默认监听 4000 端口。如果编译有问题,会抛出错误信息。
  • 4)查看效果

用浏览器打开 http://localhost:4000/http://127.0.0.1:4000/ 查看显示书籍的效果。


网络异常,图片无法展示
|

  • 如果想发给别人看,把 localhost 换成自己电脑的 IP 地址。


gitbook新版本"gitbook build"命令导出的html不能跳转的解决办法


gitbook是一个很好用的工具,但是呢,我装了好几个版本,老是出现这个问题,于是请教周围的前端大神,大神提出了解决方法,这个问题倒是可以暂时解决,具体一劳永逸的做法还没找到,谁知道了,别忘了告诉我一声啊!

可能原因

新版本的gitbook不支持了这个功能

具体原因

由于点击事件被js代码禁用,所以点击没有反应,但是如果右键,在新窗口/新标签页打开的话是可以跳转的

解决办法

找到js代码,并修改

找到项目目录gitbook

找到目录下的theme.js文件

找到下面的代码

将if(m)改成if(false)

由于代码是压缩后的,会没有空格,搜索的时候可以直接搜索: if(m)for(n.handler&&

if (m)
    for (n.handler && (i = n,
    n = i.handler,
    o = i.selector),
    o && de.find.matchesSelector(Ye, o),
    n.guid || (n.guid = de.guid++),
    (u = m.events) || (u = m.events = {}),
    (a = m.handle) || (a = m.handle = function(t) {
        return "undefined" != typeof de && de.event.triggered !== t.type ? de.event.dispatch.apply(e, arguments) : void 0
    }
    ),
    t = (t || "").match(qe) || [""],
    l = t.length; l--; )
        s = Ze.exec(t[l]) || [],
        h = g = s[1],
        d = (s[2] || "").split(".").sort(),
        h && (f = de.event.special[h] || {},
        h = (o ? f.delegateType : f.bindType) || h,
        f = de.event.special[h] || {},
        c = de.extend({
            type: h,
            origType: g,
            data: r,
            handler: n,
            guid: n.guid,
            selector: o,
            needsContext: o && de.expr.match.needsContext.test(o),
            namespace: d.join(".")
        }, i),
        (p = u[h]) || (p = u[h] = [],
        p.delegateCount = 0,
        f.setup && f.setup.call(e, r, d, a) !== !1 || e.addEventListener && e.addEventListener(h, a)),
        f.add && (f.add.call(e, c),
        c.handler.guid || (c.handler.guid = n.guid)),
        o ? p.splice(p.delegateCount++, 0, c) : p.push(c),
        de.event.global[h] = !0)
    }

完成修改

保存,测试可用

推荐阅读