1158 字
6 分钟
Expressive Code 示例
本文将介绍使用 Expressive Code 时代码块的呈现效果。以下示例基于官方文档,你可以参考以了解更多细节。
Expressive Code
语法高亮
常规语法高亮
console.log('这段代码已启用语法高亮!')渲染 ANSI 转义序列
ANSI 颜色:- 常规:红 绿 黄 蓝 品红 青- 粗体: 红 绿 黄 蓝 品红 青- 淡化: 红 绿 黄 蓝 品红 青
256 色(展示 160–177 号色):160 161 162 163 164 165166 167 168 169 170 171172 173 174 175 176 177
完整 RGB 颜色:森林绿 - RGB(34, 139, 34)
文本格式:粗体 淡化 斜体 下划线编辑器与终端边框
代码编辑器边框
console.log('title 属性示例')<div>文件名注释示例</div>终端边框
echo "这个终端边框没有标题"Write-Output "这个终端边框有标题!"覆盖边框类型
echo "看,没有边框!"# 若不覆盖,这里会显示为终端边框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)
function demo() { console.log('这一行被标记为删除') // 这一行和下一行被标记为插入 console.log('这是第二条插入行')
return '这一行使用默认的中性标记类型'}为行标记添加标签
<button role="button" {...props} value={value} className={buttonClassName} disabled={disabled} active={active}> {children && !active && (typeof children === 'string' ? <span>{children}</span> : children)}</button>在独立行上添加长标签
<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('「是」和「的」这两个字会被标记。')转义正斜杠
echo "测试" > /home/test.txt选择行内标记类型(mark、ins、del)
function demo() { console.log('这些是已插入和已删除的标记类型'); // return 语句使用默认标记类型 return true;}自动换行
按代码块配置自动换行
// 启用 wrap 的示例function getLongString() { return '这是一段非常长的字符串,除非容器极宽,否则很可能无法完整显示在当前可用空间内'}// 禁用 wrap 的示例(wrap=false)function getLongString() { return '这是一段非常长的字符串,除非容器极宽,否则很可能无法完整显示在当前可用空间内'}配置换行行的缩进
// 启用 preserveIndent 的示例(默认开启)function getLongString() { return '这是一段非常长的字符串,除非容器极宽,否则很可能无法完整显示在当前可用空间内'}// 禁用 preserveIndent 的示例(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://caph.me/posts/expressive-code/