1074 字
5 分钟
Expressive Code 示例

这里我们将探索如何使用 Expressive Code 展示代码块。以下示例基于官方文档,详情可参考官方说明。

Expressive Code#

语法高亮#

语法高亮

常规语法高亮#

console.log('这段代码已高亮显示!')

渲染 ANSI 转义序列#

Terminal window
ANSI 颜色:
- 普通: 绿 洋红
- 加粗: 绿 洋红
- 变暗: 绿 洋红
256 色(显示 160-177):
160 161 162 163 164 165
166 167 168 169 170 171
172 173 174 175 176 177
全 RGB 颜色:
森林绿 - RGB(34, 139, 34)
文本格式:加粗 变暗 斜体 下划线

编辑器与终端框#

编辑器与终端框

代码编辑器框#

my-test-file.js
console.log('Title 属性示例')

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 行 - 按范围 "7-8" 标记
// 第 8 行 - 按范围 "7-8" 标记

选择行标记类型(mark, ins, del)#

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>

在独立行添加长标签#

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 风格语法#

这一行将被标记为插入
这一行将被标记为删除
这是一行普通内容

--- a/README.md
+++ b/README.md
@@ -1,3 +1,4 @@
+这是真实的 diff 文件
-所有内容都不会被修改
没有空白会被移除

结合语法高亮与 diff 风格语法#

function thisIsJavaScript() {
// 整个代码块会以 JavaScript 高亮,
// 同时可以添加 diff 标记!
console.log('旧代码将被移除')
console.log('新代码上线!')
}

标记行内指定文本#

function demo() {
// 标记行内任意指定文本
return '支持多次匹配指定文本';
}

正则表达式#

console.log('yesyep 都会被标记。')

转义斜杠#

Terminal window
echo "Test" > /home/test.txt

选择行内标记类型(mark, ins, del)#

function demo() {
console.log('这些是插入和删除标记类型');
// return 语句使用默认标记类型
return true;
}

自动换行#

自动换行

每个代码块配置自动换行#

// 自动换行示例
function getLongString() {
return '这是一个很长的字符串,除非容器非常宽,否则很可能无法完全显示'
}

// wrap=false 示例
function getLongString() {
return '这是一个很长的字符串,除非容器非常宽,否则很可能无法完全显示'
}

配置换行缩进#

// preserveIndent 示例(默认启用)
function getLongString() {
return '这是一个很长的字符串,除非容器非常宽,否则很可能无法完全显示'
}

// preserveIndent=false 示例
function getLongString() {
return '这是一个很长的字符串,除非容器非常宽,否则很可能无法完全显示'
}

可折叠区块#

可折叠区块

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('来自第 2 行的问候!')
console.log('我在第 3 行')

// 此代码块不显示行号
console.log('你好?')
console.log('你知道我在第几行吗?')

更改起始行号#

console.log('来自第 5 行的问候!')
console.log('我在第 6 行')
Expressive Code 示例
https://blog.170529.xyz/posts/expressive-code/
作者
Starfallen
发布于
2024-04-10
许可协议
CC BY-NC-SA 4.0