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>
相关推荐
_OP_CHEN2 小时前
【前端开发之CSS】(四)CSS 常用元素属性宝典(下):背景与圆角进阶指南,让页面颜值飙升!
前端·css·html·页面开发·gui开发·css元素属性
光影少年2 小时前
react和vue多个组件在一个页面展示不同内容都是请求一个接口,如何优化提升率性能
前端·vue.js·react.js
aPurpleBerry2 小时前
React 组件:组件通信、受控组件&非受控组件、异步组件、HOC高阶组件
前端·react.js·前端框架
匠心网络科技2 小时前
前端框架-Vue双向绑定核心机制全解析(二)
前端·javascript·vue.js·前端框架
晚霞的不甘2 小时前
Flutter 方块迷阵游戏开发全解析:构建可扩展的关卡式益智游戏
前端·flutter·游戏·游戏引擎·游戏程序·harmonyos
咕噜咕噜啦啦2 小时前
HTML速通
前端·vscode·html·html5
肖。35487870942 小时前
窗口半初始化导致的BadTokenException闪退!解决纯Java开发的安卓软件开局闪退!具体表现为存储中的缓存为0和数据为0。
android·java·javascript·css·html
我是伪码农10 小时前
Vue 1.23
前端·javascript·vue.js
毕设源码-郭学长15 小时前
【开题答辩全过程】以 基于Web的高校课程目标达成度系统设计与实现为例,包含答辩的问题和答案
前端