Typora中绕过主题html方式自定义字体的一个设置问题


USER 🧑‍💻

typora中输入markdown, 字体采用html代码修改为 方正仿宋_GBK 并加粗之后,发现有些字,"查"、"全"、"金"、"理"...... 都不以加粗的形式显示,与其它字正常的加粗不同,请搜索和分析可能的原因,并给出解决方案,简单、科学,仍在typora应用中实现


MODEL ✨

这是一个在Typora(以及所有基于Chromium内核的编辑器)中非常经典的问题。

核心原因分析

简单来说,"方正仿宋_GBK"这个字体文件本身没有"粗体(Bold)"版本,它只有一个标准(Regular)版本。

当你在代码中要求 font-weight: bold 时,Typora 会尝试通过算法"强行加粗"(把字横向拉宽或描边,称为 Synthetic Bold )。但由于"方正仿宋_GBK"是老旧的GBK编码字体,兼容性较差,Chromium内核在渲染这种"伪粗体"时经常出现渲染丢字(Glyph Render Issue),导致部分汉字(通常是笔画较复杂的字)无法正确应用加粗效果,看起来像细体。


解决方案:使用 CSS "描边"模拟加粗

我们不能依赖不稳定的系统自动加粗,而是要用 CSS 手动给文字"描一层边",这样100% 能够实现加粗效果,且对所有汉字一视同仁。

请使用以下代码替换你原来的 HTML 代码:

html 复制代码
<span style="font-family: '方正仿宋_GBK'; -webkit-text-stroke: 0.6px currentcolor;">
    这里是你的文本,所有的字(查、全、金、理)都会被均匀加粗。
</span>
代码原理:
  • -webkit-text-stroke: 0.6px currentcolor; :这是关键。
    • 它不使用 font-weight: bold,而是直接给文字边缘画一条线。
    • 0.6px 是描边的厚度,你可以根据需要调整(建议 0.5px - 0.8px 之间,太粗会糊在一起)。
    • currentcolor 让描边颜色自动跟随字体颜色(无论是黑色还是其他颜色)。
为什么这个方案科学?
  1. 绕过内核缺陷 :它不再依赖字体的 Bold 属性,彻底避开了"有没有粗体文件"的系统判断。
  2. 视觉统一:它是图形层面的加粗,所有字符(无论简单还是复杂)都会增加同样的厚度。
  3. 完全兼容 :Typora 基于 Web 技术,完美支持 -webkit-text-stroke 属性。

进阶方案(如果你不想每次都写这么长)

如果你经常需要使用这个格式,建议在 Typora 的主题 CSS 文件中定义一个类。

  1. 打开 Typora,点击 文件 -> 偏好设置 -> 外观 -> 打开主题文件夹
  2. 创建一个名为 base.user.css 的文件(如果已有则打开)。
  3. 在里面加入这段代码:
css 复制代码
/* 定义一个名为 .fz-bold 的样式类 */
.fz-bold {
    font-family: "方正仿宋_GBK", "FangSong", serif;
    /* 关掉默认加粗,改用描边 */
    font-weight: normal; 
    -webkit-text-stroke: 0.6px currentcolor;
}
  1. 保存文件。
  2. 以后在 Typora 里,只需要写简短的标签即可:
html 复制代码
<span class="fz-bold">查全金理</span>

这样既解决了问题,又简化了操作。


USER 🧑‍💻

不定义一个css类,直接在文章markdown的html代码中如何修改和添加


MODEL ✨

直接在 Markdown 中,将你的 HTML 代码修改为以下形式即可:

html 复制代码
<span style="font-family: '方正仿宋_GBK'; font-weight: normal; -webkit-text-stroke: 0.6px currentColor;">
    你要加粗的文字(如:查、全、金、理)
</span>

关键修改点说明:

  1. 添加 -webkit-text-stroke: 0.6px currentColor;
    • 这是用来"模拟加粗"的代码。
    • 0.6px 是加粗的粗细。如果你觉得不够粗,可以改成 0.8px;觉得太粗了就改成 0.5px
  2. 强制设置 font-weight: normal;
    • 非常重要 :必须显式地写上 normal
    • 如果不写,某些情况下 Typora 还是会尝试启动它自带的"伪加粗"算法,导致你的"描边加粗"和系统的"算法加粗"重叠,字迹会变得非常模糊刺眼。
  3. 使用 currentColor
    • 这样能保证加粗部分的颜色和你文字本身的颜色完全一致,不会出现黑边或其他杂色。

直接复制这段去用即可:

复制代码
<span style="font-family: '方正仿宋_GBK'; font-weight: normal; -webkit-text-stroke: 0.6px currentColor;">这里输入文字</span>
相关推荐
小码哥_常6 分钟前
Room 3.0:移动端持久化的“重生”变革
前端
Front思1 小时前
前端的.hbs
前端
_.Switch1 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI1 小时前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
普通网友1 小时前
ES6模块化、Promise、async、await、EventLoop、API接口案例_export function 与 await
前端·ecmascript·es6
難釋懷1 小时前
Vue混入
前端·javascript·vue.js
若梦plus1 小时前
TypeScript进阶
前端·javascript·typescript·ecmascript
直奔標竿1 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
@PHARAOH2 小时前
WHAT - cursor cli 开发范式
前端·ai·ai编程
子兮曰3 小时前
深入 HTML-in-Canvas:当 Canvas 学会了渲染 DOM,前端图形生态要变天了
前端·javascript·canvas