1115 字
6 分钟
表达性代码示例

在这里,我们将探讨如何使用表达性代码展示代码块。提供的示例基于官方文档,您可以参考该文档以获取更多详细信息。

表达性代码#

语法高亮#

语法高亮

常规语法高亮#

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('标题属性示例')
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 "测试" > /home/test.txt

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

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

换行#

换行

为每个块配置换行#

// 换行示例
function getLongString() {
return 'This is a very long string that will most probably not fit into the available space unless the container is extremely wide'
}
// 示例为wrap=false
function getLongString() {
return 'This is a very long string that will most probably not fit into the available space unless the container is extremely wide'
}

配置换行行缩进#

// 示例为preserveIndent(默认启用)
function getLongString() {
return 'This is a very long string that will most probably not fit into the available space unless the container is extremely wide'
}
// 示例为preserveIndent=false
function getLongString() {
return 'This is a very long string that will most probably not fit into the available space unless the container is extremely wide'
}

可折叠部分#

可折叠部分

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行')
表达性代码示例
https://ifimi.cn/posts/expressive-code/
作者
发布于
2024-04-10
许可协议
CC BY-NC-SA 4.0