Markdown 是一种标记语言,
类似于换行、列表符号等等,这些在 Word 以及各种常见的笔记应用中只是作为内容;
但在 Markdown 里,这些也是识别的语法。
Obsidian 便是一款基于 Markdown 的编辑器。
它的编辑模式类似“源代码”,而阅读模式类似“输出结果”。
它的渲染显示,始终受到 Markdown 这简化的 HTML 的“限制”,或者说,规范。
“空白压缩”是 Markdown 重要的特性。
任何紧邻前后的空格和 Tab ——不管是 1 个还是 100 个——都会被一起清理,压缩到只剩一个空格。
所以,你必须在段落间空一行,也即使用连续 2 个换行符,才能在阅读模式获得一个新的段落块(<p>
),
因为 1 个换行符只会变成 1 个空格。
而当其间没有内容分隔时,不论你在编辑模式连续换多少行,阅读模式都将渲染出唯一的一行。
所以,你看到不加标号的文本正好放在列表序号下,以为是换行缩进了;
但在编辑器眼里,其实只有一个“内容中间有空格的一行的列表项”,
只不过是给用户折行显示出来了。
不空一行 = 无法被识别为新的段落。不加标号 = 无法被识别为新的列表。
识别不了 = 没有分出新的块。不加标号的缩进 = 没有缩进。
1. 标题1
段落1
等于
1. 标题1
段落1
等于
- 标题1 段落1
没有分出新的块,对于程序是同一个东西,也就无法分开引用、应用不同的样式、运行不同的脚本。
不论如何,Obsidian 首先是一款 Markdown 编辑器,
因此不能超越标记语言以纯文本实现富文本付出的规范。
其他规范,例如表格前后必须空一行,否则就无法渲染,
这些都是 Obsidian 底层逻辑不可或缺的一部分。
如果你已囤积了一些使用不加标号的缩进的文档,想要解决也很简单。
可以使用 Ob 自带的无序、有序列表命令一键转换,
也可以使用【解答合集】批量添加删除修改查找替换 中的其他办法。
客制需求纵生千千万,规范写法恒居上上策。