前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Safari浏览器统一字体之自定义CSS样式表

Safari浏览器统一字体之自定义CSS样式表

原创
作者头像
QinAi
修改2024-10-29 12:35:39
4200
修改2024-10-29 12:35:39

这段CSS的主要目的是针对Safari浏览器自定义的样式表,实现了大部分全局样式尤其字体的统一设定,字体设定为系统字体。

代码语言:css
复制
/* 设置根元素的字体和代码字体变量 */
:root {
    --font-family: -apple-system; /* 使用系统默认的字体 */
    --code-font-family: ui-monospace; /* 设置代码字体为系统默认的等宽字体 */
    -webkit-font-smoothing: antialiased !important; /* 在Webkit浏览器中启用字体抗锯齿 */
}

/* 为HTML元素设置字体和文本渲染优化 */
:where(html) {
    font-family: var(--font-family) !important; /* 使用根元素中定义的字体变量 */
    letter-spacing: -.0245rem; /* 字母间距微调 */
    text-rendering: optimizeLegibility; /* 优化文本可读性 */
}

/* 为段落和标题元素设置单词换行 */
:where(p, h1, h2, h3, h4, h5, h6) {
    overflow-wrap: break-word; /* 长单词或URL在必要的时候可以换行 */
}

/* 为常见的文本和列表元素设置字体 */
:where(body, p, h1, h2, h3, h4, h5, h6, ol, ul, blockquote, q, u, cite, strong, dfn, abbr, acronym, address, small, select, textarea, th, td, dd, dt, font, label, input) {
    font-family: var(--font-family) !important; /* 使用根元素中定义的字体变量 */
}

/* 为代码相关的元素设置代码字体和字体大小 */
:where(code, kbd, pre, samp, var, tt, time) {
    font-family: var(--code-font-family) !important; /* 使用代码字体变量 */
    font-size: 1em; /* 代码字体大小设置为1em */
}

/* 排除伪元素和特定类名的元素,为其他元素设置字体 */
:not(::before, ::after):not(.svg, .iconfont, .far, .fat, .fab, .fas, .fa-gear, .fa) {
    font-family: var(--font-family),inherit !important; /* 使用根元素中定义的字体变量,或者继承父元素的字体 */
}

/* 为链接、加粗、强调、列表项等元素设置字体 */
:where(a, b, em, li, div, div > span, td > span, p > span, img + span):not([class*="font"], [class*="ico"], [class*="Ico"]) {
    font-family: var(--font-family),inherit !important; /* 使用根元素中定义的字体变量,或者继承父元素的字体 */
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档