
在Stylus中优雅地扩展网页字体
网页字体通常通过font-family属性设置,例如:font-family: -apple-system, blinkmacsystemfont;。但如果想在现有字体列表前添加自定义字体(例如,通过@font-face声明的my-custom字体),直接修改font-family属性较为繁琐,尤其当不确定原有字体列表内容时。
关键在于如何动态获取并修改CSS的font-family属性,而不破坏原有设置。CSS本身缺乏方便的字符串操作,因此需要借助JavaScript。
Zyro AI Background Remover
Zyro推出的AI图片背景移除工具
55 查看详情
一种高效方法是使用JavaScript获取元素的font-family属性值,然后将自定义字体添加到该值前面。以下代码片段演示了如何实现:
const el = document.body;const prevFontFamily = getComputedStyle(el).getPropertyValue('font-family');el.style.fontFamily = 'MyCustom, ' + prevFontFamily;
这段代码首先获取document.body元素的font-family属性值,存储在prevFontFamily变量中。然后,它将自定义字体MyCustom与原有字体列表连接,并将其赋值给el.style.fontFamily,从而将自定义字体添加到字体列表开头。此方法避免了直接修改CSS代码的复杂性,并确保了原有字体设置的完整性。 需要注意的是,这通过JavaScript操作DOM元素的样式属性,而非直接修改CSS文件。
以上就是如何在Stylus中优雅地扩展网页字体?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1124975.html
微信扫一扫
支付宝扫一扫