空色天絵 / NEO TOKYO NOIR 01
1115 字
6 分钟
表达性代码示例
在这里,我们将探讨如何使用表达性代码展示代码块。提供的示例基于官方文档,您可以参考该文档以获取更多详细信息。
表达性代码
语法高亮
常规语法高亮
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('标题属性示例')<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('单词yes和yep将被标记。')转义斜杠
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=falsefunction 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=falsefunction 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行')