使用 Shortcode

    本页面介绍了可用的 shortcode 及其用法。

    将图片文件跟 markdown 文件放在相同的目录。为了增强其可读性,以及方便本地化,首选的图片格式是 SVG。下面的示例展示了添加带有图片的 shortcode ,所需的必填字段:

    caption 字段是必填字段,shortcode 还支持可选字段,例如:

    1. {{< image width="75%" ratio="45.34%"
    2. link="./<image.svg>"
    3. alt="<使用屏幕阅读器且图片加载失败时使用的备用文本>"
    4. title="<鼠标悬停在图片上时显示的文本>"
    5. caption="<图片下方显示的标题>"
    6. >}}

    如果你没有填写 alt 字段,Hugo 会自动使用 title 的文本。如果你没有填写 title 字段,Hugo 会自动使用 caption 的文本。

    width 字段设置图像相对于周围文本的大小,默认为 100%。

    Ratio 字段设置图像相对于其宽度的高度。Hugo 会自动为目录中的图片计算该值。但是,对于外部图片,您必须手动为其计算。将 ratio 的值设置为 ([图片高度]/[图片宽度]) * 100

    添加图标

    您可以将通用图标嵌入到具有以下内容的内容中:

    1. {{< warning_icon >}}
    2. {{< idea_icon >}}
    3. {{< checkmark_icon >}}
    4. {{< cancel_icon >}}
    5. {{< tip_icon >}}

    图标会呈现在文本中,例如:、使用 Shortcode - 图2、、使用 Shortcode - 图4 以及 。

    添加指向其它页面的链接

    根据目标的不同,Istio 文档支持三种类型的链接。每种类型使用不同的语法来表示链接目标。

    • 外部链接。用于指向 Istio 在 GitHub 的仓库,或者其它的站外链接。使用标准的 Markdown 语法表示 URL。当你引用的文件在互联网上时,请尽量使用 HTTPS 协议,例如:

      1. [链接的描述文本](https://mysite/myfile.html)
    • 绝对链接。用于指向当前页面之外,但位于 Istio 站点之内页面的目标。绝对路径以斜线 / 开头,例如:

    无论使用何种类型,链接都不会指向内容的 index.md 文件,而是指向包含 index.md 的那个目录。

    有几种方法可以引用 GitHub 的内容或文件:

    • {{< github_file >}},用于引用 GitHub 中的单个文件(例如 yaml 文件)。该 shortcode 会渲染为 https://raw.githubusercontent.com/istio/istio*,例如:

      1. [liveness]({{< github_file >}}/samples/health-check/liveness-command.yaml)
    • {{< github_tree >}},用于引用 GitHub 中的一个目录。该 shortcode 会渲染为 https://github.com/istio/istio/tree*,例如:

      1. [httpbin]({{< github_tree >}}/samples/httpbin)
    • {{< github_blob >}},用于引用 GitHub 中的单个文件,该 shortcode 会渲染为 https://github.com/istio/istio/blob*,例如:

      1. [RawVM MySQL]({{< github_blob >}}/samples/rawvm/README.md)

    想要通过从网站检索,在您的内容中显示 Istio 的当前版本,请使用以下 shortcode :

    • {{< istio_version >}},渲染结果为:1.13
    • ,渲染结构为:1.13.2

    术语表

    当您在页面中介绍一个 Istio 术语时,贡献补充条款要求您将该术语包含在 glossary 中,并使用 shortcode {{< gloss >}} 标记它的第一个实例。shortcode 会对其进行特殊渲染,读者点击该术语,可以在弹出的窗口中获取该术语的定义。例如:

    1. Istio 里的组件通过控制 {{<gloss>}}Envoy{{</gloss>}} 代理,实现服务发现、负载均衡和路由分发。

    渲染结果如下:

    Istio 里的组件通过控制 Envoy 代理,实现服务发现、负载均衡和路由分发。

    如果你想在您的文本中使用该术语的其它形式,您依然可以使用该 shortcode 。要修改显示文本,只需在 shortcode 中包含对应的术语条目即可。例如:

    术语 envoy 定义的渲染结果如下:

    Istio 里的组件通过控制 Envoy 代理,实现服务发现、负载均衡和路由分发。

    标注

    想要强调部分内容,可以将它们设置为警告,提示,建议或引用。所有标注都使用了非常相似的 shortcode :

    1. {{< warning >}}
    2. 这是一个重要的警告
    3. {{< /warning >}}
    4. {{< idea >}}
    5. 这是一个好点子
    6. {{< /idea >}}
    7. {{< tip >}}
    8. 这是来自专家的有用建议
    9. {{< /tip >}}
    10. {{< quote >}}
    11. {{< /quote >}}

    上面的 shortcode 渲染结果如下:

    这是一个重要的警告

    这是一个好点子

    这是来自专家的有用建议

    这是从某处引用的内容

    应该谨慎地使用标注。每种类型的标注都有特定的用途,过度使用会适得其反。通常,每个文件最多只能包含一个标注。

    要想在保持内容单一来源的情况下重用内容,请使用样板 shortcode 。要将样板文本嵌入任何内容文件中,请使用 boilerplate shortcode ,如下所示:

    1. {{< boilerplate example >}}

    下面的 shortcode 包含了 /content/zh/boilerplates/ 目录下 example.md 文件的内容:

    这是一些 markdown 文本的样板。

    1. 嵌套文本块样本的例子。

    使用选项卡

    要显示具有多个选项或格式的内容,请使用选项卡和选项卡集。其可用于显示:

    • 不同平台的等效命令
    • 不同语言的等效代码
    • 替代的配置

    要添加选项卡式内容,请组合使用 shortcode tabsettabs,例如:

    1. {{< tabset category-name="platform" >}}
    2. {{< tab name="One" category-value="one" >}}
    3. ONE
    4. {{< /tab >}}
    5. {{< tab name="Two" category-value="two" >}}
    6. {{< /tab >}}
    7. {{< tab name="Three" category-value="three" >}}
    8. THREE
    9. {{< /tab >}}
    10. {{< /tabset >}}

    上面的 shortcode ,渲染效果如下:

    One Two Three

    ONE

    TWO

    THREE

    每个选项卡的 name 属性的值就是该选项卡显示的文本。在每个选项卡内部,支持绝大部分的 Markdown 语法,但是选项卡有一些。

    category-namecategory-value 属性是可选的,它们让选定的标签可以跨页面存储。例如,访问者选择一个选项卡,并使用给定的名称和值自动保存他们的选择。如果有多个选项卡集使用了相同的 category-namecategory-value,则它们的选择将自动跨页面同步。当站点中有许多具有相同类型格式的选项卡集时,此功能特别有用。

    例如,有多个选项卡集都提供了 GCPBlueMixAWS 三个选项。您可以将 category-name 属性的值设置为 environment,将 category-value 属性的值设置为gcp,接着是 bluemixaws。然后,当读者在某一个选项卡集中做出选择时,网站上所有相同的选项卡集都会自动做出相同的选择。

    选项卡限制

    您可以在选项卡中使用几乎所有的 Markdown 语法,但以下情况除外:

    • *标题*。选项卡中的标题会出现在目录中,但是单击目录中的链接不会自动跳到选项卡的位置。

    • *嵌套选项卡集*。不要嵌套选项卡集。这么做会导致阅读体验很糟糕,并可能导致严重的混乱。

    使用横幅和标签

    要通告即将发生的事件或发布新消息,您可以按顺序自动地将对时间敏感的横幅和标签(banners and stickers)添加至生成的网站。我们为通告实现了以下 shortcode :

    • 倒计时标签:它会显示现在距离事件发生还有多少时间,例如:“距 3 月 30 日 ServiceMeshCon 还剩 37 天”。标签在活动开始前会对读者产生视觉影响,应谨慎使用。

    要创建横幅和标签,您可以在 events/bannersevents/stickers 目录中创建 Markdown 文件。每个事件一个 Markdown 文件,并使用专用的 front-matter 字段来控制其行为。下表列举了可用的字段: