开发工具分享
  • 首页
  • 计算科学
  • 文化旅游
  • 项目和网站
    • OSSEZ 计算技术
    • USRealEstate 社区
    • 地区文化
    • CWIKI.US
    • BUG.OSSEZ.COM
    • RSS.OSSEZ.COM
CWIKIUS.CN
一个有独立思考和温度的清新站
  1. Home
  2. Computer Science
  3. This article

Discourse 发布代码或者格式化文本

2024年11月29日 703Browse 0Like 0Comments

当有代码希望在 Discourse 中进行分享的时候,或者针对一些错误日志需要发布在 Discourse 上的时候。如果我们不对代码进行格式化,对于这些内容读起来是非常费劲的,

同时在很多代码中会包含有空格和一些其他的字符,那么在内容转换的时候,这些内容就会脱离其本意了。

 

726fe68d5b6a7733c56efbb00ab99b0cddd632f7

概要

在本指南中,你可以学到:

  • 如何格式化行内代码。
  • 如何格式化单行代码。
  • 如何格式化多行代码。
  • 如何为代码格式化使用 BBCode 和 HTML。
  • 如何禁用代码自动格式化。

行内代码格式化

要对行内的代码或者特殊文字进行格式化,在需要进行格式化的内容前后部分使用单引号。

这个可以是在一个文本中,或者代码在另外一行 。

行内代码格式化不会为要格式化的代码应用任何格式(请查看下面的示例),只会对要格式化的代码使用代码样式(“code style”)。

示例 1:

输入:

`This is a line of code`

输出:

This is a line of code

示例 2:

输入:

Here’s some text with `a bit of code` inside!

输出:

Here’s some text with a bit of code inside!

单行代码格式化

如果需要对当行的代码进行格式化,那么只需要在当行的代码前面添加 4 个空格就行。

单行中的所有内容都会被格式化成代码,直到下一行的开始。

示例:

输入:

    All text after 4 spaces will be formatted.

输出:

All text after 4 spaces will be formatted.

多行代码格式化

针对多行代码,如果还使用单行代码进行格式化的话,那么整个过程就会显得非常麻烦。

尤其是很多代码还会使用空格进行缩进。

使用单行空格代码格式化将会影响整个代码块的缩进。

这个时候可以使用 3 个单引号(backticks (```))作为代码的开头,这 3 个单引号需要独立成行。

同时,这个 3 个单引号之前不能有空格,如果有空格的话,整个代码块可能无法格式化。

示例:

输入:

``` 
public class CodeFormatting {
    public static void main(String[] args) {
        System.out.println("I can format code now!");
    }
}
```

输出:

public class CodeFormatting {
    public static void main(String[] args) {
        System.out.println("I can format code now!");
    }
}

BBCode 和 HTML

除了 Markdown 格式化外,Discourse 还能够支持 BBCode 和 HTML。

针对 HTML 使用 <pre> 和 <code> 标签:

<pre><code>
public class CodeFormatting {
    public static void main(String[] args) {
        System.out.println("I can format code now!");
    }
}
</code></pre>

针对 BBCode,使用 [code] 标签:

[code]
public class CodeFormatting {
    public static void main(String[] args) {
        System.out.println("I can format code now!");
    }
[/code]

针对特定的程序语言

在默认情下,Discourse 会针对你的输入格式来自动侦测使用的语言。

当然你也可以手动针对代码块指定语言,在 3 个单引号后面输入你希望格式化的语言即可。

``` your_language
# Your code here

示例:

针对 Ruby 语言:

输入:

``` ruby
3.times do |stuff|
    stuff.do
end
```

输出:

3.times do |stuff|
    stuff.do
end

能够支持的语言必须是下面能够支持语法高亮的语言 highlighted languages`。

能够支持的语言列表可以在 on GitHub 页面中访问到。

当然,你可以可以使用 default code lang 配置来配置默认的语言。

不使用语法高亮

如果你不希望输入的文本或者代码块使用任何语法高亮,那么在语言选择部分使用 text 来代替。

示例:

输入:

``` text
Your text to NOT highlight here

输出:

Your text to NOT highlight here

最佳实践

  • 针对行内代码,总是使用单引号来包裹你需要格式化的文本。
  • 如果要分享多行代码,把代码进行格式化。
  • 针对文本和日志,避免使用自动代码样式,因为这些文本多是纯文本,之间使用文本格式就好了。
  • 当发现自动样式识别没有对代码进行正确识别的时候,记得为你的代码指定正确的语言。

 

https://www.isharkfly.com/t/discourse/16675

Tags: None
Last updated:2024年11月29日

HoneyMoose

有温度的人文和独立的思考

Like
< Previous
Next >

Comments

Cancel reply

Archives
  • May 2026
  • April 2026
  • March 2026
  • February 2026
  • January 2026
  • December 2025
  • November 2025
  • October 2025
  • September 2025
  • August 2025
  • July 2025
  • June 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • October 2024
  • September 2024
  • August 2024
  • July 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • May 2022
  • April 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • June 2021
  • May 2021
  • April 2021
  • March 2021
  • February 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • April 2020
  • March 2020
  • February 2020
  • January 2020
  • December 2019
  • November 2019
  • October 2019
  • September 2019
  • August 2019
  • July 2019
  • June 2019
  • May 2019
  • April 2019
  • March 2019
  • February 2019
  • January 2019
  • December 2018
  • November 2018
  • October 2018
  • September 2018
  • August 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
Categories
  • Computer Science (2,362)
    • Confluence (663)
    • Gradle (12)
  • U.S. (482)
  • 文化旅游 (145)

COPYRIGHT © 2020 CWIKIUS. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

湘ICP备2020018253号-1