现代CSS样式重置最佳实践!(下)

简介: 现代CSS样式重置最佳实践!(下)

现代CSS样式重置最佳实践!(上)https://developer.aliyun.com/article/1411402


5. 平滑字体


body {
  -webkit-font-smoothing: antialiased;
}

在 MacOS 电脑上,浏览器默认使用“亚像素抗锯齿”。 这是一种旨在通过利用每个像素内的 R/G/B 光使文本更易于阅读的技术。过去,这被视为可访问性的胜利,因为它提高了文本对比度。

在 2018 年发布的 MacOS Mojave 中,Apple 禁用了整个操作系统的亚像素抗锯齿功能。然而,像 Chrome 和 Safari 这样的 MacOS 浏览器默认情况下仍然使用子像素抗锯齿。 我们需要通过将 -webkit-font-smoothing 设置为 antialiased 来关闭它。

下图中,左侧是关闭之后的效果:

5.webp.jpg

MacOS 是唯一使用子像素抗锯齿的操作系统,因此此规则对 Windows、Linux 或移动设备并没有影响。 如果使用的是 MacOS 计算机,则可以比较两者的实时渲染(没有使用CSS重置):

p {
  -webkit-font-smoothing: subpixel-antialiased;
  font-family: sans-serif;
}
.antialiased {
  -webkit-font-smoothing: antialiased;
}

效果如下:

5.webp.jpg


6. 媒体默认值


img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

在 HTML 中,图像被认为是内联元素。这意味着它应该用在段落中间,像一样。这与大多数时候使用图像的方式不一致。 通常,对待图像的方式与对待段落、标题的方式相同,都是布局元素。

但是,如果尝试在布局中使用内联元素,就会发生奇怪的事情。 如果你曾经有过一个神秘的 4px 间隙,它不是paddingmarginborder,它可能是浏览器用行高添加的内联空间。

通过给图片设置 display: block 就避免了这种问题。除此之外,还设置了max-width: 100%。这样做是为了防止大图溢出,如果它们被放置在了一个不够宽的容器中。大多数块级元素会自动增长/收缩以适应其父元素,但像 这样的媒体元素很特殊:它们被称为替换元素,并且它们不遵循这些规则。

如果图像的原始尺寸为 800×600,即使将其放入宽度为 500px 的父元素中,其宽度也将是 800px。这条规则将防止该图像超出其容器,这可能是更明智的默认行为。


7. 继承表单控件的字体


input, button, textarea, select {
  font: inherit;
}

默认情况下,按钮和输入框不会从其父元素继承排版样式。 相反,它们有自己的怪异风格。例如,</code> 将使用系统默认的等宽字体。<code>input</code> 输入将使用系统默认的无衬线字体。 两者都将选择很小的字体大小(在 Chrome 中为 13.333px)。在移动设备上阅读 13 px 的文本会很困难。 当聚焦一个小字体的 input 时,浏览器会自动放大,让文本更容易阅读。</div><div>这是一个不太好的体验</div><div>如果想要避免这种自动缩放行为,输入的字体大小至少需要 1rem / 16px。 下面是解决该问题的一种方法:</div><div><span><br /></span></div><pre><code><span>input</span>, <span>button</span>, <span>textarea</span>, select { <span>  <span>font-size</span>: <span>1rem</span>;</span> <span>}</span> </code></pre><div>这的确解决了自动缩放问题,但这这是表面上的。 这个问题的根本原因是:<strong>表单输入不应该有自己的排版样式</strong>。</div><div><span><br /></span></div><pre><code><span>input</span>, <span>button</span>, <span>textarea</span>, select { <span>  <span>font</span>: inherit;</span> <span>}</span> </code></pre><div>font 是一种很少使用的速记,它设置了一些与字体相关的属性,如 <code>font-size</code>、<code>font-weight</code>、<code>font-family</code>。 通过将其设置为 <code>inherit</code>,就指定这些元素与其周围环境中的排版相匹配。只要不为正文设置很小的字体,这样做就可以解决这些问题。</div><div><br /></div><h2 id="tGVgG">8. 自动换行</h2><div><br /></div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22p%2C%20h1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%20%7B%5Cn%20%20overflow-wrap%3A%20break-word%3B%5Cn%7D%5Cn%22%2C%22heightLimit%22%3Atrue%2C%22margin%22%3Atrue%2C%22id%22%3A%22vJV54%22%7D"></div><div>在 CSS 中,如果一行中没有足够的空间容纳所有字符,文本将自动换行。默认情况下,算法会寻找“软换行”的机会,这些是算法可以拆分的字符。 在英语中,唯一的软换行机会就是空格和连字符,但这因语言而异。</div><div>如果一行中没有任何软换行机会,并且它不适合换行,就会导致文本溢出:</div><div><span data-card-type="inline" data-ready-card="image" data-card-value="data:%7B%22src%22%3A%22https%3A%2F%2Fucc.alicdn.com%2Fpic%2Fdeveloper-ecology%2Fyjbvedpo6nmku_c3174f82b019496a8f7237c8dd841c35.jpg%22%2C%22originWidth%22%3A1336%2C%22originHeight%22%3A688%2C%22name%22%3A%228.webp.jpg%22%2C%22size%22%3A155183%2C%22display%22%3A%22inline%22%2C%22align%22%3A%22left%22%2C%22linkTarget%22%3A%22_blank%22%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22search%22%3A%22%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%2C%22width%22%3A1336%2C%22height%22%3A688%7D"></span></div><div>这可能会导致出现水平滚动条,也可能会导致文本与其他元素重叠,或者滑到图像/视频后面。</div><div><code>overflow-wrap</code> 属性可以调整换行算法,并允许它在找不到软换行机会时使用硬换行:</div><div><span data-card-type="inline" data-ready-card="image" data-card-value="data:%7B%22src%22%3A%22https%3A%2F%2Fucc.alicdn.com%2Fpic%2Fdeveloper-ecology%2Fyjbvedpo6nmku_c9ca0101af784a7ea84491d96acb62db.jpg%22%2C%22originWidth%22%3A1334%2C%22originHeight%22%3A780%2C%22name%22%3A%228.webp%20(1).jpg%22%2C%22size%22%3A209212%2C%22display%22%3A%22inline%22%2C%22align%22%3A%22left%22%2C%22linkTarget%22%3A%22_blank%22%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22search%22%3A%22%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%2C%22width%22%3A1334%2C%22height%22%3A780%7D"></span></div><div>除此之外,还可以尝试添加 hyphens 属性:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22p%20%7B%5Cn%20%20overflow-wrap%3A%20break-word%3B%5Cn%20%20hyphens%3A%20auto%3B%5Cn%7D%5Cn%22%2C%22heightLimit%22%3Atrue%2C%22margin%22%3Atrue%2C%22id%22%3A%22CXXPk%22%7D"></div><div>hyphens: auto 使用连字符(在支持它的语言中)来指定硬换行,它使硬换行更加普遍。如果文本列非常窄,这可能是值得的,但它也可能有点分散注意力。所以并没有将其包含在重置中,但值得一试!</div><div><br /></div><h2 id="04g1p">9. 根层叠上下文</h2><div><br /></div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%23root%2C%20%23__next%20%7B%5Cn%20%20isolation%3A%20isolate%3B%5Cn%7D%5Cn%22%2C%22heightLimit%22%3Atrue%2C%22margin%22%3Atrue%2C%22id%22%3A%22WwU7m%22%7D"></div><div>这一项是是可选的。 通常只有在使用像 React 这样的 JavaScript 框架时才需要它。isolation 属性允我们创建一个新的层叠上下文,而无需设置 z-index。这就可以保证某些高优先级元素(例如模态框、下拉菜单、tooltip)将始终显示在应用中的其他元素之上。</div><div>我们需要根据使用的框架来调整选择器,该选择器选择的是应用中渲染的顶级元素。例如,<code>create-react-app</code> 使用的是 <code><div id="root"></code>,所以应该使用选择器<code>#root</code>。</div><div>最后,再来看一下这些重置样式的完整代码,可以将其复制/粘贴到自己的项目中:</div><div data-card-type="block" data-ready-card="codeblock" data-card-value="data:%7B%22mode%22%3A%22plain%22%2C%22code%22%3A%22%5Cn*%2C%20*%3A%3Abefore%2C%20*%3A%3Aafter%20%7B%5Cn%20%20box-sizing%3A%20border-box%3B%5Cn%7D%5Cn*%20%7B%5Cn%20%20margin%3A%200%3B%5Cn%7D%5Cnhtml%2C%20body%20%7B%5Cn%20%20height%3A%20100%25%3B%5Cn%7D%5Cnbody%20%7B%5Cn%20%20line-height%3A%201.5%3B%5Cn%20%20-webkit-font-smoothing%3A%20antialiased%3B%5Cn%7D%5Cnimg%2C%20picture%2C%20video%2C%20canvas%2C%20svg%20%7B%5Cn%20%20display%3A%20block%3B%5Cn%20%20max-width%3A%20100%25%3B%5Cn%7D%5Cninput%2C%20button%2C%20textarea%2C%20select%20%7B%5Cn%20%20font%3A%20inherit%3B%5Cn%7D%5Cnp%2C%20h1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%20%7B%5Cn%20%20overflow-wrap%3A%20break-word%3B%5Cn%7D%5Cn%23root%2C%20%23__next%20%7B%5Cn%20%20isolation%3A%20isolate%3B%5Cn%7D%5Cn%22%2C%22heightLimit%22%3Atrue%2C%22margin%22%3Atrue%2C%22id%22%3A%225yF6Y%22%7D"></div><blockquote><div><strong>参考文章:</strong><a href="https://link.juejin.cn?target=https%3A%2F%2Fwww.joshwcomeau.com%2Fcss%2Fcustom-css-reset%2F" target="_blank" ref="nofollow noopener noreferrer">www.joshwcomeau.com/css/custom-…</a></div></blockquote>

相关文章
|
5月前
|
前端开发
如何设置 CSS 盒子模型的边框样式?
CSS盒子模型的边框样式可以通过`border`属性设置,包括边框宽度、样式和颜色。例如:`border: 2px solid red;` 设置了2像素宽的红色实线边框。也可分别设置四边,如`border-top`、`border-right`等。
|
3月前
|
JavaScript 前端开发
jQuery和CSS3斑马线样式range滑块特效
jQuery和CSS3斑马线样式range滑块特效
|
4月前
|
前端开发 JavaScript UED
|
5月前
|
前端开发 JavaScript
CSS样式穿透技巧:利用scoped与deep实现前端组件样式隔离与穿透
CSS样式穿透技巧:利用scoped与deep实现前端组件样式隔离与穿透
498 1
|
5月前
|
编解码 前端开发 JavaScript
使用 CSS 打印样式为 Web 页面设置专业的打印机效果
使用 CSS 打印样式为 Web 页面设置专业的打印机效果
123 2
|
4月前
|
前端开发
HTML 样式- CSS3
内部样式表适用于单个文件的特别样式,通过&lt;head&gt;部分的&lt;style&gt;标签定义;外部样式表适用于多个页面,通过&lt;link&gt;标签引用外部CSS文件;&lt;style&gt;定义样式,&lt;link&gt;引用资源;已弃用的标签有&lt;font&gt;、&lt;center&gt;、&lt;strike&gt;,属性有color和bgcolor。
HTML 样式- CSS2
HTML样式实例展示了如何使用`font-family`、`color`和`font-size`属性来定义字体样式,以及使用`text-align`属性来设置文本的对齐方式。示例包括标题和段落的样式设置。
|
4月前
|
前端开发
HTML 样式- CSS1
CSS (层叠样式表) 用于为 HTML 元素添加样式,包括颜色、文本、盒子模型等。CSS 可以通过内联样式、内部样式表或外部引用的方式添加到 HTML 中。推荐使用外部引用方式。本教程将介绍如何使用 CSS 为 HTML 添加样式,并提供实例演示。
|
5月前
|
前端开发 Ubuntu Linux
CSS 修改鼠标图标样式
CSS 修改鼠标图标样式
69 0
|
5月前
|
前端开发 容器
CSS实现旋转圆角叠加样式,你学会了吗?
CSS实现旋转圆角叠加样式,你学会了吗?
59 0

热门文章

最新文章