905 字
  5 分钟
   富有表现力的代码示例 
 在这里,我们将探索代码块如何使用 富有表现力的代码.. 提供的示例基于官方文档,您可以参考这些文档了解更多详细信息。
富有表现力的代码
语法高亮
常规语法突出显示
console.log('This code is syntax highlighted!')渲染 ANSI 转义序列
ANSI colors:- Regular: Red Green Yellow Blue Magenta Cyan- Bold:    Red Green Yellow Blue Magenta Cyan- Dimmed:  Red Green Yellow Blue Magenta Cyan
256 colors (showing colors 160-177):160 161 162 163 164 165166 167 168 169 170 171172 173 174 175 176 177
Full RGB colors:ForestGreen - RGB(34, 139, 34)
Text formatting: Bold Dimmed Italic Underline编辑器和终端框架
代码编辑器框架
console.log('Title attribute example')<div>File name comment example</div>终端框架
echo "This terminal frame has no title"Write-Output "This one has a title!"覆盖框架类型
echo "Look ma, no frame!"# Without overriding, this would be a terminal framefunction Watch-Tail { Get-Content -Tail 20 -Wait $args }New-Alias tail Watch-Tail文本与行标记
标记整行与行范围
// Line 1 - targeted by line number// Line 2// Line 3// Line 4 - targeted by line number// Line 5// Line 6// Line 7 - targeted by range "7-8"// Line 8 - targeted by range "7-8"选择行标记类型(标记、插入、删除)
function demo() {  console.log('this line is marked as deleted')  // This line and the next one are marked as inserted  console.log('this is the second inserted line')
  return 'this line uses the neutral default marker type'}为行标记添加标签
<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 的语法
this line will be marked as insertedthis line will be marked as deletedthis is a regular line--- a/README.md+++ b/README.md@@ -1,3 +1,4 @@+this is an actual diff file-all contents will remain unmodified no whitespace will be removed either结合语法高亮与类似差异的语法
function thisIsJavaScript() {  // This entire block gets highlighted as JavaScript,  // and we can still add diff markers to it!  console.log('Old code to be removed')  console.log('New and shiny code!')}在行内标记单个文本
function demo() {  // Mark any given text inside lines  return 'Multiple matches of the given text are supported';}正则表达式
console.log('The words yes and yep will be marked.')转义前导斜杠
echo "Test" > /home/test.txt选择内联标记类型(mark、ins、del)
function demo() {  console.log('These are inserted and deleted marker types');  // The return statement uses the default marker type  return true;}自动换行
为每个区块配置自动换行
// Example with wrapfunction getLongString() {  return 'This is a very long string that will most probably not fit into the available space unless the container is extremely wide'}// Example with 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'}配置包裹行的缩进
// Example with preserveIndent (enabled by default)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'}// Example with 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
// All this boilerplate setup code will be collapsedimport { someBoilerplateEngine } from '@example/some-boilerplate'import { evenMoreBoilerplate } from '@example/even-more-boilerplate'
const engine = someBoilerplateEngine(evenMoreBoilerplate())
// This part of the code will be visible by defaultengine.doSomething(1, 2, 3, calcFn)
function calcFn() {  // You can have multiple collapsed sections3 collapsed lines
  const a = 1  const b = 2  const c = a + b
  // This will remain visible  console.log(`Calculation result: ${a} + ${b} = ${c}`)  return c}
4 collapsed lines
// All this code until the end of the block will be collapsed againengine.closeConnection()engine.freeMemory()engine.shutdown({ reason: 'End of example boilerplate code' })行号
每个代码块显示行号
// This code block will show line numbersconsole.log('Greetings from line 2!')console.log('I am on line 3')// Line numbers are disabled for this blockconsole.log('Hello?')console.log('Sorry, do you know what line I am on?')更改起始行号
console.log('Greetings from line 5!')console.log('I am on line 6')