搜索
首页web前端css教程流体图像以变量比例布局

Fluid Images in a Variable Proportion Layout

处理独立布局中的流体图像如今已相当容易。然而,对于更复杂的界面,我们经常需要将图像放置在响应式元素内,例如这张卡片:

假设此图像是非语义内容,仅作装饰。这非常适合使用background-image。并且,由于此图像包含对象,我们不能在响应式布局时裁剪任何部分,因此我们选择background-size: contain

问题在于:在移动设备上,此卡片方向发生变化并变为垂直方向,图像位于顶部。我们可以使用任何类型的 CSS 布局技术实现这一点,并且可能最好使用 CSS 网格或弹性盒。

但是,当我们测试较小的屏幕时,由于contain属性,我们会得到以下结果:

这不太理想。图像调整大小以保持其纵横比,不会裁剪任何细节,如果图像是重要内容并且不应裁剪,则我们不能将background-size更改为cover

此时,我们的下一个尝试可能很熟悉:将图像内联放置,而不是背景。

在桌面设备上,这可以正常工作:

在移动设备上也不错:

但在较小的屏幕上,由于所有固定大小,图像的比例会失真。

我们可以花费数小时来调整图像、卡片和弹性属性,来回调整。或者,我们可以……

将主要内容与背景分离

这是在响应式图像方面获得更大灵活性和弹性的基础。虽然并非在所有情况下都能实现,但在许多情况下,只需在设计方面稍加努力即可实现,尤其是在预先计划这种方法的情况下。

在我们的下一次迭代中,我们将草莓图像放在透明背景上,并使用 CSS 设置光栅图像中的蓝色。通过调整样本空间的大小,继续在演示中使用视口大小进行操作!

仔细查看样式,请注意我们还向包含图像的 div 添加了填充,因此草莓不会过于靠近边缘。我们可以通过此填充完全控制我们希望它们有多近或多远。

请注意,我们还使用负边距来补偿外部卡片包装上的填充,否则图像周围会出现空白。

对内联图像使用 object-fit 属性

尽管之前的演示有效,但我们仍然可以改进这种方法。到目前为止,我们假设该图像是无语义内容——但在此布局中,图像插图也可能不仅仅是装饰。

如果是这种情况,我们绝对不希望图像被裁剪,因为这实际上相当于数据丢失。为了防止这种情况,最好将图像内联放置而不是背景,我们可以使用object-fit属性来实现。

我们已从背景中提取草莓,它现在是一个内联元素,但我们保留了同一图像 div 中的背景颜色。

最后,将object-fit: contain100%宽度相结合,可以调整窗口大小并保持草莓的纵横比。但是,这种方法的缺点是,我们需要为桌面版本的图像设置固定高度——否则它将遵循设置宽度的比例(降低它会改变布局)。如果我们需要使用可变数量的文本生成这些卡片,这些文本会换行,这可能会使事情过于受限。

即将推出:aspect-ratio

上述问题的解决方案可能即将通过即将推出的aspect-ratio属性实现。这将允许设置元素的固定比例,例如:

.el {
  aspect-ratio: 16 / 9;
}

这意味着我们将能够消除固定高度并将其替换为我们计算的纵横比。例如,我们最后一个示例的桌面断点中的尺寸如下所示:

.image {
  /* ... */
  height: 184px;
  width: 318px;
}

使用aspect-ratio,我们可以删除高度声明并进行计算以获得最接近 184 的比例:

.image {
  /* ... */
  width: 318px; /* 基准宽度 */
  height: unset; /* 重置在媒体查询之外设置的高度 */
  aspect-ratio: 159 / 92; /* 接近 184px 高度 */
}

如果您想了解更多信息,可以在本文中更深入地探讨即将推出的属性。

最后,有多种方法可以在可变比例布局中实现可靠的响应式图像。但是,使这项工作更容易——并且更好——的技巧不一定在于 CSS;它可能很简单,只需调整您的图像,无论是将前景与背景分离(就像我们所做的那样),还是选择即使裁剪了相当一部分边缘仍然有效的特定图像。

以上是流体图像以变量比例布局的详细内容。更多信息请关注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

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

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

SublimeText3 英文版

SublimeText3 英文版

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

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

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

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。