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>
相关推荐
用户693717500138442 分钟前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦1 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013841 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水2 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫3 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll1234 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
蓝冰凌5 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛5 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
柳杉6 小时前
从动漫水面到赛博飞船:这位开发者的Three.js作品太惊艳了
前端·javascript·数据可视化