855 字
4 分钟
Expressive Code 示例

这里演示 Expressive Code 在当前站点中的显示效果。它适合用来展示代码、终端输出、diff、行高亮、折叠区块和行号。

语法高亮#

普通代码块#

console.log('这段代码会被语法高亮。')

ANSI 转义序列#

Terminal window
ANSI 颜色:
- 普通:红色 绿色 黄色 蓝色 洋红 青色
- 加粗:红色 绿色 黄色 蓝色 洋红 青色
- 变暗:红色 绿色 黄色 蓝色 洋红 青色
文本格式:加粗 变暗 斜体 下划线

编辑器和终端边框#

编辑器标题#

my-test-file.js
console.log('这个代码块带有标题。')
src/content/index.html
<div>也可以通过文件名注释生成标题。</div>

终端边框#

Terminal window
echo "这是一个没有标题的终端代码块"
PowerShell 终端示例
Write-Output "这个终端代码块有标题。"

覆盖边框类型#

echo "这个代码块不显示边框。"
PowerShell Profile.ps1
function Watch-Tail { Get-Content -Tail 20 -Wait $args }
New-Alias tail Watch-Tail

文本与行标记#

标记整行或行范围#

// 第 1 行会被标记
// 第 2 行
// 第 3 行
// 第 4 行会被标记
// 第 5 行
// 第 6 行
// 第 7 行和第 8 行会被标记
// 第 8 行

区分新增、删除和普通标记#

line-markers.js
function demo() {
console.log('这一行会显示为删除')
// 这一行和下一行会显示为新增
console.log('这是第二行新增内容')
return '这一行使用默认标记样式'
}

给行标记增加标签#

labeled-line-markers.jsx
<button
role="button"
{...props}
value={value}
className={buttonClassName}
disabled={disabled}
active={active}
>
{children &&
!active &&
(typeof children === 'string' ? <span>{children}</span> : children)}
</button>

diff 风格代码块#

这一行会显示为新增
这一行会显示为删除
这一行是普通内容
function thisIsJavaScript() {
console.log('旧代码')
console.log('新代码')
}

标记行内文本#

function demo() {
// 可以标记行内出现的给定文本
return '多个给定文本也会被标记';
}
console.log('正则表达式会标记 yesyep。')
Terminal window
echo "Test" > /home/test.txt

自动换行#

为单个代码块开启换行#

function getLongString() {
return '这是一段很长很长的字符串,如果容器宽度不够,它会按照设置自动换行,避免撑破文章布局。'
}
function getLongString() {
return '这段长字符串不会主动换行,适合检查横向滚动和代码块宽度。'
}

控制换行后的缩进#

function getLongString() {
return '开启 preserveIndent 时,换行后的缩进会尽量保持原来的代码结构。'
}
function getLongString() {
return '关闭 preserveIndent 后,换行后的缩进不会继续跟随原始缩进。'
}

折叠区块#

5 collapsed lines
// 这些样板代码会默认折叠
import { someBoilerplateEngine } from '@example/some-boilerplate'
import { evenMoreBoilerplate } from '@example/even-more-boilerplate'
const engine = someBoilerplateEngine(evenMoreBoilerplate())
// 这部分会默认展开
engine.doSomething(1, 2, 3, calcFn)
function calcFn() {
// 一个代码块里可以有多个折叠区间
3 collapsed lines
const a = 1
const b = 2
const c = a + b
// 这一行保持可见
console.log(`计算结果:${a} + ${b} = ${c}`)
return c
}
4 collapsed lines
// 结尾的清理代码也会折叠
engine.closeConnection()
engine.freeMemory()
engine.shutdown({ reason: '示例代码结束' })

行号#

为单个代码块显示行号#

console.log('这段代码会显示行号。')
console.log('这一行在第 2 行。')
console.log('这段代码不会显示行号。')
console.log('适合短代码片段。')

修改起始行号#

console.log('这一行显示为第 5 行。')
console.log('这一行显示为第 6 行。')
Expressive Code 示例
https://blog.glacia.fun/posts/expressive-code/
作者
SeraphinaGlacia
发布于
2024-04-10
许可协议
CC BY-NC-SA 4.0