搜索
首页web前端css教程简化的流体版式

Simplified Fluid Typography

流体排版是指字体大小(以及可能的其他字体属性,如行高)根据屏幕大小(或者如果我们有的话,容器查询)而变化的理念。

其核心技巧在于视口单位。您可以直接使用视口单位设置字体(例如 font-size: 4vw),但是大小的波动非常剧烈,通常不可取。这可以通过使用类似 font-size: calc(16px 1vw) 的方法来缓和。但是,既然我们已经开始使用复杂的计算,最常见的实现方法最终变成了一个用普通英语表达的等式:

我希望字体大小在 320 像素屏幕上为 16 像素,在 1000 像素屏幕上为 22 像素。

最终结果如下:

html {
  font-size: 16px;
}
@media screen and (min-width: 320px) {
  html {
    font-size: calc(16px   6 * ((100vw - 320px) / 680));
  }
}
@media screen and (min-width: 1000px) {
  html {
    font-size: 22px;
  }
}

这实际上是设置了字体的最小值最大值,以防止字体缩小或增大到过大的程度。“CSS 锁定”是 Tim Brown 创造的一个术语。

您说是最小值最大值?!碰巧的是,min()max() 函数已经以这些形式进入了 CSS 规范。

因此,我们可以使用单行代码简化上面的复杂设置并保持锁定:

html {
  font-size: min(max(1rem, 4vw), 22px);
}

我们实际上可能想就此打住,因为尽管 Safari (11.1 ) 和 Chrome (79 ) 目前都支持此功能,但这已经是目前所能达到的最大支持范围了。说到这里,您可能需要在此之前添加一个 font-size 声明,以设置一个没有复杂函数的合理回退值。

但是,只要我们还在挑战极限,还有另一个函数可以进一步简化事情:clamp()clamp() 接受三个值:最小值、最大值和中间的灵活单位(或计算或任何其他内容),如果值在最小值和最大值之间,它将使用中间值。因此,我们的单行代码变得更小了:

body {
  font-size: clamp(100%, 1rem   2vw, 24px);
}

这将适用于 Chrome 79 (尚未发布到稳定版,但很快就会发布)。

Dave 叔非常高兴 FitText 现在只有几字节大小,而不是整个 jQuery 加上 40 多行代码。这是 Dave 向其添加 CSS 自定义属性的情况:

刚刚看到这个不错的解释:

早上开发者新闻:CSS clamp 可用于流体排版。?

? clamp 在 MDN 上:https://www.php.cn/link/4ac20f72e05b86b3dc759608b60f5d67

视频替代文本:示例展示了如何将 clamp 用于 h1 元素的流体/响应式排版 pic.twitter.com/9iiCxxXJO7

— Stefan Judis (@stefanjudis) 2020 年 4 月 20 日

以上是简化的流体版式的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
锚定位只是不关心来源订单锚定位只是不关心来源订单Apr 29, 2025 am 09:37 AM

锚定定位避开HTML源顺序的事实是如此css-y,因为它在内容和演示文稿之间的另一个关注点分离。

保证金是什么:40px 100px 120px 80px表示?保证金是什么:40px 100px 120px 80px表示?Apr 28, 2025 pm 05:31 PM

文章讨论了CSS保证金属性,特别是“保证金:40px 100px 120px 80px”,其应用程序以及对网页布局的影响。

什么是不同的CSS边框特性?什么是不同的CSS边框特性?Apr 28, 2025 pm 05:30 PM

本文讨论了CSS边境属性,重点是自定义,最佳实践和响应能力。主要论点:边境 - 拉迪乌斯(Border-Radius)对响应式设计最有效。

什么是CSS背景,列出属性?什么是CSS背景,列出属性?Apr 28, 2025 pm 05:29 PM

本文讨论了CSS背景属性,它们在增强网站设计方面的用途以及避免的常见错误。重点是使用背景大小的响应式设计。

什么是CSS HSL颜色?什么是CSS HSL颜色?Apr 28, 2025 pm 05:28 PM

文章讨论了CSS HSL颜色,其在网络设计中的使用以及比RGB的优势。主要重点是通过直观的颜色操纵来增强设计和可访问性。

我们如何在CSS中添加评论?我们如何在CSS中添加评论?Apr 28, 2025 pm 05:27 PM

本文讨论了CSS中评论的使用,详细介绍了单线和多行评论语法。它认为注释可以增强代码可读性,可维护性和协作,但如果无法正确管理,可能会影响网站性能。

什么是CSS选择器?什么是CSS选择器?Apr 28, 2025 pm 05:26 PM

本文讨论了CSS选择器,其类型和用于造型HTML元素的用法。它比较ID和类选择器,并与复杂的选择器解决性能问题。

哪种类型的CSS持有最高优先级?哪种类型的CSS持有最高优先级?Apr 28, 2025 pm 05:25 PM

本文讨论了CSS优先级,重点是具有最高特异性的内联风格。它解释了特异性级别,覆盖方法和用于管理CSS冲突的工具。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器