喜欢在中英文间插入空格的博主都知道,WP有一款插件叫“空格爱好者”(Space Lover),由软件作者Tunghsiao Liu编写。整体代码简洁明了,以preg_replace
与正则表达式来判断和添加中英文间的空格,达到悦目的效果。
当然插件也不是完美无缺,毕竟自动插入空格后会导致复制文本时带入额外空格,以及中英文间的空格过宽且无法单独自定义。
还有个偷懒办法是直接设置letter-spacing: 0.15rem
,但所有文本都相应宽了。
改进方法:
- 正则表达式将
' '
替换为'<span class="space"></span>'
- CSS中设置
.space {margin:0 0.1rem;}
代码举例:
$content = preg_replace('~(\p{Han})([a-zA-Z0-9\p{Ps}\p{Pi}])(?![^<]*>)~u', '\1'.'<span class="space"></span>'.'\2', $content);
效果:




注:<span>会出现在浏览器标签页中,有洁癖者慎加。
好棒,居然还有这样的插件!强迫症狂喜
@Jack哈哈哈
已复制粘贴,感谢。
@木頭人不客气。
我是习惯性在输入英文和数字的时候两边敲一下空格。
@不亦乐乎这是个好习惯,就是对懒人不适用
中文输入好像会有点间隙吧!英文没有
@网友小宋Windows下有一丢丢,Mac下没有。
😄,我现在是手动加space
@木瓜园手动就有点累,有违懒惰之宗旨。😄
@S是的,手动麻烦。
能否换个思路,发日志的时候处理,在写入系统之前替换,不用每次读取做替换,性能会有提升。
@木瓜园这应该不难,甚至写个比如bat脚本线下处理都行。
@S我准备踩坑试试
@木瓜园😀