模板

GitBook 可使用模板特性来扩展定制化功能。

GitBook 使用 NunjucksJinja2 的语法。

语法使用大括号{}来标记需要处理的内容。

变量

变量会从书本内容中寻找对应的值。

如果你想简单地显示一个变量,你可以使用{{variable}}语法。

定义变量

变量被定义在 book.json 文件中:

{
    "variables": {
        "gitbook-guide": "Gitbook 简明教程。"
    }
}

这样定义了一个变量 gitbook-guide,取值为 "Gitbook 简明教程。"

显示变量

定义在 book.json 中的变量可以在 book 作用域下被访问:

这会从书本的变量中寻找 gitbook-guide 并显示它。变量的名字可以存在点 (dot) 来查找属性。你同样可以使用方括号语法。

在页面上{{ book.gitbook-guide }}的语法会被显示为 -> NaN

在页面上{{ book["gitbook-guide"] }}的语法会被显示为 ->

如果对应的值没有定义,那么什么也不会显示。

下面这些语句不会输出任何东西,如果 foo 没有定义的话:

{{ book.foo }}{{ book.foo.far }}{{ book.foo.bar.baz }}

在页面上{{ book.foo }}的语法会被显示为 ->

什么都没有被显示出来,是因为根本没有定义该变量。

上下文变量

一些变量也可以用来获取当前文件或 GitBook 实例的信息。

变量内容比较多,参见 变量

标签

标签是在章节和模板中执行操作的特殊块

If

if 测试一个条件并让你选择性的显示内容。它的行为的和编程语言中的 if 一样。

如果 variable 被定义了并且是真的,那么 "变量为真" 就会被显示出来。否则,没有任何东西会被显示。

    {% if variable %}
        变量为真
    {% endif %}

你可以使用 elif 和 else 来指定选择性条件:

    {% if hungry %}
        我很饿
    {% elif tired %}
        我很累
    {% else %}
        我很好!
    {% endif %}

for

for 迭代数组和字典。

让我们来看一下 book.json 中的变量:

{ 
  "variables": { 
    "ides": [ { "name": "Eclipse" }, { "name": "IntelliJ IDEA" },{ "name": "Visual Studio Code" } ]
  }
 }

编程常用的 IDE:

{% for ides in ide %}

{{ide.name}}

{% endfor %}

上面的例子使用 ides 数组的每项的 name 属性作为显示的值,列出了所有的 IDE。

转义

如果你想要输出任何特殊的目标标签,你可以使用 raw,任何在其中的内容都会原样输出。

{% raw %}
   这些内容 {{ 不会被处理 }}
{% endraw %}
Copyright & Copy zha0cai该文件修订时间: 2024-03-28 15:32:43

results matching ""

    No results matching ""