Typst-codelst 包使用指南:优雅排版代码的技术实践
2025-06-24 08:30:02作者:乔或婵
前言
在技术文档编写过程中,代码展示是不可或缺的重要元素。typst-codelst 包正是为解决 Typst 文档中的代码排版问题而生,它提供了丰富的代码展示功能,让技术文档编写变得更加专业和高效。
安装与导入
作为包使用(Typst 0.9.0及以上版本)
对于较新的 Typst 版本,可以直接从预览仓库导入:
#import "@preview/codelst:2.0.2": sourcecode
作为模块使用
将 codelst.typ 文件放入项目目录后,可以直接导入:
#import "codelst.typ": sourcecode
核心功能详解
基础代码展示
sourcecode 命令是 typst-codelst 的核心功能,它包装了 Typst 的 raw 块,为其添加了丰富的格式化选项:
#sourcecode[```typ
#show "ArtosFlow": name => box[
#box(image(
"logo.svg",
height: 0.7em,
))
#name
]
```]
行号定制
typst-codelst 提供了灵活的行号显示方式:
#sourcecode(
numbers-side: right,
numbering: "I", // 使用罗马数字
numbers-start: 10, // 起始行号
numbers-step: 4, // 行号步长
numbers-style: (i) => align(right, text(fill:blue, emph(i))),
frame: none
)[```typ
// 你的代码
```]
代码框架样式
默认情况下,代码块会显示在浅灰色背景的块元素中。可以通过 frame 参数完全自定义:
#let myframe = block.with(
fill: fuchsia.lighten(96%),
stroke: 1pt + fuchsia,
radius: 2pt,
inset: (x: 10pt, y: 5pt)
)
#sourcecode(frame: myframe)[```typ
// 你的代码
```]
外部文件导入
sourcefile 命令可以直接展示外部文件内容:
#sourcefile(read("example.py"), file:"example.py")
为简化使用,可以创建别名:
#let sourcefile(filename, ..args) = codelst.sourcefile(read(filename), file:filename, ..args)
行引用功能
typst-codelst 支持代码行标记和引用:
// 在代码中添加标记
public static void main(String[] args) { // <main-entry>
System.out.println("Hello World!");
}
然后在文档中引用:
参见#lineref(<main-entry>)处的入口方法
高级技巧
空白处理
typst-codelst 会自动处理代码中的空白:
- 移除开头和结尾不必要的空行
- 消除多余的缩进
可通过 showlines 和 gobble 参数控制此行为。
与其他包集成
typst-codelst 可以与其他样式包如 showybox 结合使用:
#import "@preview/showybox:2.0.1": showybox
#let showycode = sourcecode.with(
frame: (code) => showybox(
frame: (
title-color: red.darken(40%),
body-color: red.lighten(90%),
border-color: black,
thickness: 2pt
),
title: "Source code",
code
)
)
全局代码样式设置
通过 show 规则可以为所有特定语言的代码块应用样式:
#show raw.where(lang: "clst-typ"): code => sourcecode(lang:"typ", code)
```clst-typ
// 你的代码
## 参数参考
### sourcecode 主要参数
| 参数 | 说明 | 默认值 |
|------|------|--------|
| `lang` | 代码语言 | 自动检测 |
| `numbering` | 行号格式 | "1" |
| `numbers-start` | 起始行号 | auto |
| `numbers-side` | 行号位置 | left |
| `highlighted` | 高亮行号列表 | () |
| `highlight-color` | 高亮颜色 | rgb(234,234,189) |
| `label-regex` | 行标记正则表达式 | `// <([a-z-]{3,})>$` |
| `frame` | 代码框样式函数 | code-frame |
## 结语
typst-codelst 为 Typst 文档中的代码展示提供了专业级的解决方案。无论是简单的代码片段展示,还是需要复杂行号管理和行引用的技术文档,typst-codelst 都能完美胜任。通过灵活的配置选项,你可以轻松实现各种风格的代码展示效果,使你的技术文档更加清晰和专业。
建议读者结合示例文档进行实践,逐步探索 typst-codelst 提供的各种可能性,找到最适合自己文档风格的配置方式。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
最新内容推荐
Error Correction Coding——mathematical methods and algorithms:深入理解纠错编码的数学精髓 HP DL380 Gen9iLO固件资源下载:提升服务器管理效率的利器 RTD2270CLW/RTD2280DLW VGA转LVDS原理图下载介绍:项目核心功能与场景 JADE软件下载介绍:专业的XRD数据分析工具 常见材料性能参数pdf下载说明:一键获取材料性能参数,助力工程设计与分析 SVPWM的原理及法则推导和控制算法详解第四修改版:让电机控制更高效 Oracle Instant Client for Microsoft Windows x64 10.2.0.5下载资源:高效访问Oracle数据库的利器 鼎捷软件tiptop5.3技术手册:快速掌握4gl语言的利器 源享科技资料大合集介绍:科技学习者的全面资源库 潘通色标薄全系列资源下载说明:设计师的创意助手
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
523
3.72 K
Ascend Extension for PyTorch
Python
329
388
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
877
578
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
335
161
暂无简介
Dart
762
188
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
745
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
React Native鸿蒙化仓库
JavaScript
302
349
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
113
136