单插件+CSS 管理连续空格,2 空格、4 空格及以上

更新:我把自己的需求融合到一个插件里了,欢迎围观 240812 更新


原帖:准备 Dynamic Highlights 插件。CSS 片段文后给出。

适用场景,包括但不限于:

  • 中英混排、调整英文句子时,容易出现句中连续 2 空格。
  • 使用 Shift + Enter 软换行时,搞不清行首有几个空格。
效果 GIF,点击展开

20231125_121119

对只有使用需求的,跟随步骤配置即可。
对有修改需求的,各部分后附说明(默认折叠),可参阅学习修改。

注:更新至 Insider v1.5.0 后 Ob 原装列表样式过于不符合我的审美,本文是在关闭“显示缩进参考线”的条件下进行测试的。

对 v1.5.0 原装列表样式的吐槽

平时:4 个空格而已,默认你空辣么大干啥

image

使用 Control Characters 插件 查看空格时:更大了

20231125_101955


插件配置

从左往右依次:

  1. 输入名称:SP2
  2. 点击圆点,点击 Clear,清除默认颜色。
  3. 输入匹配内容:2 个空格。
  4. 保持正则关闭,点击 Save

因为插件的 Save 按钮中间区域交互有点问题,建议点击按钮边缘区域进行保存。

用同样的方法,再添加一个名称 SP4,输入匹配内容:4 个空格,保持正则关闭,点击 Save

说明

这一段操作,相当于通过插件,我们为所有匹配内容左右加上了<span class="SP2"> </span><span class="SP4"> </span> 的 HTML 代码。

现在,我们文档中所有连续 2 个空格都将应用 <span class="SP2"> 指定的 CSS 样式,而所有连续 4 个空格都将应用 <span class="SP4"> 指定的 CSS 样式,彼此之间按照 HTML 元素的排列,可以互相嵌套。


CSS 配置

Dynamic Highlights 插件的作用是创建新的 span class,因此对其应用 CSS 只需像其他 CSS 片段一样放在 Ob 的 snippets 文件夹下。

如果不知道什么是添加 CSS,此链接有详细说明:CSS 分享:自动隐藏式十字花左侧边栏

效果展示 CSS 代码:

.SP2:not(.SP4 .SP2:nth-of-type(1)) {background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg"><rect x="1.6" y="-1" width="40%" height="110%" fill="none" stroke="hsla(90, 100%, 50%, 0.6)" /></svg>');}

为了避免行首奇数空格,如效果展示中引用块第二行无序列表行首 5 个空格,CSS 将右边线调得离文本较近。这样,当文本明显与线拉开了距离,就能判断出现了奇数空格。

说明

.SP2:not(.SP4 .SP2:nth-of-type(1)) 指定除了 class="SP4" 下第一个 class="SP2" 元素外所有 class="SP2" 的元素的样式。

url(' ') 中为 SVG,<rect /> 这段代码创建了一个矩形。

  • x="1.6" 表示矩形的左上角相对于 SVG 视口左侧的水平位置为 1.6 个单位。
  • y="-1" 表示矩形的左上角相对于 SVG 视口顶部的垂直位置为 -1 个单位。
  • width="40%" 表示矩形的宽度为 SVG 视口宽度的 40%。
  • height="110%" 表示矩形的高度为 SVG 视口高度的 110%。
  • fill="none" 表示矩形内部不填充颜色,即透明。
  • stroke="hsla(90, 100%, 50%, 0.6)" 表示矩形边框的颜色为 hsla 色彩模式中色相为 90 度、饱和度为 100%、亮度为 50%、透明度为 0.6 的颜色。

彩蛋:常用中文全角标点左右空格管理

由于中文全角标点在显示上类似自带 1 个空格,在中英混排中确认中文全角标点两边是否有空格也是一件麻烦事,可以用同样的方式解决。

效果 GIF

20231125_143235


插件配置

Dynamic Highlights 名称:T0

匹配内容:

[!,。?;:()《》【】「」、] (?!\^|#)|(?<! |#|^( +)?-) [!,。?;:()《》【】「」、]

启用正则

CSS 配置

.T0 {text-decoration: underline dashed hsla(90, 100%, 50%, 0.6);}
说明

在正则中,管道符 | 意为“或者”,表示要匹配的内容是被管道符分隔的任意一个。

中括号 [ ] 内的内容是字符的集合,表示要匹配的字符可以是其中任意一个。这里包括全角感叹号、逗号、句号、问号、分号、冒号、括号、书名号、方括号、顿号。

也即这个正则表示匹配常用中文全角标点右边有 1 个空格或左边有 1 个空格的所有内容。

2 个赞

使用Control Charactes插件时,设定一部分css后,效果可能会好点

CSS
/* 可更改颜色,也可以默认插件的颜色 */
body {
  --control-character-color: rgba(192, 192, 192, 0.415) !important;
}

/* 段落末尾回车符号原来的有点问题,可以改为下面这个,粘贴到style Setting设置领面 */
/* 
url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg id='SVGRepo_bgCarrier' stroke-width='0'%3E%3C/g%3E%3Cg id='SVGRepo_tracerCarrier' stroke-linecap='round' stroke-linejoin='round'%3E%3C/g%3E%3Cg id='SVGRepo_iconCarrier'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M3 14a1 1 0 0 1 1-1h12a3 3 0 0 0 3-3V6a1 1 0 1 1 2 0v4a5 5 0 0 1-5 5H4a1 1 0 0 1-1-1z' fill='%230D0D0D'%3E%3C/path%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M3.293 14.707a1 1 0 0 1 0-1.414l4-4a1 1 0 0 1 1.414 1.414L5.414 14l3.293 3.293a1 1 0 1 1-1.414 1.414l-4-4z' fill='%230D0D0D'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
*/

/* 取消显示字后的换行符号->不需要最好取消掉,也可以用上面的设置来 */
.control-character[type="newline"]:after {
  content: none;
}

/* 显示换行符号 */
.cm-line:not(.HyperMD-header):has(> br)::before {
  content: "⮐";
  color: var(--control-character-color);
}

/* 去除有序列表或者无序列表前的符号 */
.markdown-source-view ol>li,
.markdown-source-view ul>li,
.markdown-preview-view ol>li,
.markdown-preview-view ul>li,
.mod-cm6 .HyperMD-list-line.cm-line::before {
  content: none;
}

1.5.0 当时列表添加新 CSS variables,后来 1.5.8 又改回去了,所以已经没有问题了。不过还是感谢分享~

1 个赞