语法高亮

语法高亮

Hugo 使用 Chroma,这是一个用纯 Go 编写的通用语法高亮器,用于语法高亮。 建议在 Markdown 内容中使用反引号来标记代码块。例如:

Markdown
```python
def say_hello():
    print("Hello!")
```

将会渲染为:

def say_hello():
    print("Hello!")

功能

文件名

要为代码块添加文件名或标题,请设置 filename 属性:

Markdown
```python {filename="hello.py"}
def say_hello():
    print("Hello!")
```
hello.py
def say_hello():
    print("Hello!")

文件链接

你可以使用 base_url 属性提供一个基础 URL,它将与文件名结合生成一个链接。

如果文件名指定了文件在基础路径中的位置,则可以包含相对路径。

Markdown
```go {base_url="https://github.com/imfing/hextra/blob/main/",filename="exampleSite/hugo.work"}
go 1.20
```

行号

要设置行号,请将 linenos 属性设置为 table,并可选地设置 linenostart 为起始行号:

Markdown
```python {linenos=table,linenostart=42}
def say_hello():
    print("Hello!")
```
42
43
def say_hello():
    print("Hello!")

高亮行

要高亮特定行,请将 hl_lines 属性设置为行号列表:

Markdown
```python {linenos=table,hl_lines=[2,4],linenostart=1,filename="hello.py"}
def say_hello():
    print("Hello!")

def main():
    say_hello()
```
hello.py
1
2
3
4
5
def say_hello():
    print("Hello!")

def main():
    say_hello()

复制按钮

默认情况下,代码块启用了复制按钮。可以通过修改站点配置文件来更改其行为:

hugo.yaml
42
43
44
45
46
47
params:
  highlight:
    copy:
      enable: true
      # hover | always
      display: hover

支持的语言

有关支持的语言列表,请参阅 Chroma 文档