css体验优化之图片容器设置宽高比

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 需求 我们在做web页面的时候,经常会有一些图片列表,例如下图的视频列表以及表情列表:        需求要求: 1. 列表是responsive的,在不同宽度的浏览器下面,图片要自适应容器宽度 2.

需求

我们在做web页面的时候,经常会有一些图片列表,例如下图的视频列表以及表情列表:

      

需求要求:

1. 列表是responsive的,在不同宽度的浏览器下面,图片要自适应容器宽度

2. 图片在自适应的过程中,图片的长宽比要保持不变

 

常规解决方案

在container宽度固定的需求中(比如PC版页面),我们直接设置图片容器或者图片为固定的宽高就好了,比如:

1 img{
2     width:330px;
3     height:180px;
4 }

 

但是这个不能满足需求,为了满足上面的需求两点,通常我们会想到通过设置图片的宽度为百分比来满足第1点,不设置高度来满足到第2点(容器的height不能根据width设置百分比),简单代码如下:

 1 ul{
 2     list-style:none;
 3 }
 4 ul li{
 5     float:left;
 6     width:100%;
 7     padding:5px;
 8 }
 9 ul li img{
10     width:100%;
11 }

 

视频时间的代码就不写出来了,通过绝对定位来做即可。

 

存在的问题

上面的解决方案虽然可行,但是条件又点苛刻,并且体验不好,为什么呢?

1. 为了做到完美显示,运营同学在配置图片的时候必须做到图片的长宽比完全一致,不能有一个像素的差别,否则会出现如下图情况:

上图中第一张图比其他三张图高一个像素,由于不能设置图片容器的高度,所以对图片大小就必须要严格控制。

2. 体验不好。当网络不佳,图片还没有加载出来的情况下,你可能看到如下图:

由于图片没有加载出来,图片没有占位,当图片加载出来后,再把容器撑高,这样的体验非常不好(特别是图片内容在首屏的时候)。

有人可能会说,使用默认图片来占位,但是有时候,在网络情况恶劣的情况下,默认图片都可能加载不出来。

 

优化方案

 为了解决上面两个存在的问题,我想到了一种使用图片容器进行占位的方法。首先我们要了解一个css的知识点,块级元素(如div,p)的padding设置为百分比的时候,是按照容器的宽度来定的,那么我们可以按照图片的比例来设置容器的高度(使用padding-top/padding-bottom),图片则使用绝对定位显示在容器的下层。

html:

 1 <div class="section-video">
 2   <ul class="list">
 3     <li>
 4       <a href="https://www.youtube.com/embed/vCS_Nl4R9W8">
 5         <div class="img">
 6           <img class="" src="http://down2.9apps.com:7080/group1/M00/76/E4/pYYBAFdlMBaAAKvkAAA0HBzaV9E798.jpg" alt="logo">
 7           <span class="time">07:12</span>
 8         </div>
 9         <span class="title">ЕВРО 2016 - ЖЕСТЬ! ТРЕНЕР СБОРНОЙ ГЕРМАНИИ ОПОЗОРИЛСЯ НА ВЕСЬ МИР</span>
10       </a>
11     </li>
12     <li>
13       <a href="https://www.youtube.com/embed/8H2VfEO4n1k">
14         <div class="img">
15           <img class="" src="http://down2.9apps.com:7080/group1/M00/B0/71/qIYBAFdlMBWARAEqAAArw8xAvK8090.jpg" alt="logo">
16           <span class="time">04:58</span>
17         </div>
18         <span class="title">ЧЕХИЯ - ХОРВАТИЯ 2:2 ОБЗОР МАТЧА </span>
19       </a>
20     </li>
21     <li>
22       <a href="https://www.youtube.com/embed/R5kRrJuolak">
23         <div class="img">
24           <img class="" src="http://down2.9apps.com:7080/group1/M01/76/E4/poYBAFdlMBmAKGmxAAA7r722CEs285.jpg" alt="logo">
25           <span class="time">03:54</span>
26         </div>
27         <span class="title">ИСПАНИЯ - ТУРЦИЯ 3:0 ОБЗОР МАТЧА </span>
28       </a>
29     </li>
30     <li>
31       <a href="https://www.youtube.com/embed/zjKbunbkU78">
32         <div class="img">
33           <img class="" src="http://down2.9apps.com:7080/group1/M00/76/E4/pYYBAFdlMBuAO13wAAA-uPs5iqo997.jpg" alt="logo">
34           <span class="time">03:14</span>
35         </div>
36         <span class="title">ИТАЛИЯ - ШВЕЦИЯ 1:0 ОБЗОР </span>
37       </a>
38     </li>
39   </ul>
40 </div>

 

css:

 1 * {
 2   box-sizing: border-box;
 3 }
 4 
 5 .section-video ul.list {
 6   padding: 5px;
 7   width: 100%;
 8   font-size: 12px;
 9   background-color: #0363b5;
10   list-style: none;
11   overflow: hidden;
12 }
13 
14 .section-video ul.list li {
15   display: inline-block;
16   width: 50%;
17   padding: 5px;
18   float: left
19 }
20 
21 .section-video ul.list li a {
22   display: block;
23   width: 100%;
24   color: #fff;
25   text-decoration: none;
26 }
27 
28 .section-video ul.list li .img {
29   width: 100%;
30   position: relative; // 使用相对定位
31   height: 0; // 高度设置为0,使用padding来设置高度
32   overflow: hidden;
33   padding-bottom: 54.545454%; // 使用padding-top也可,使用padding来撑高容器,高度为宽度的 54.545454%
34 }
35 
36 .section-video ul.list li .img img {
37   position: absolute; // 使用绝对定位
38   width: 100%; // 宽高为容器的宽高
39   height: 100%;
40   top: 0;
41   left: 0
42 }
43 
44 .section-video ul.list li .img .time {
45   position: absolute;
46   display: inline-block;
47   right: 0;
48   bottom: 15px;
49   font-size: 12px;
50   line-height: 18px;
51   background-color: rgba(0, 0, 0, .48);
52   border-top-left-radius: 8px;
53   border-bottom-left-radius: 8px;
54   padding: 0 10px
55 }
56 
57 .section-video ul.list li .title {
58   display: block;
59   line-height: 18px;
60   padding: 4px 0;
61   height: 40px;
62   overflow: hidden;
63   text-overflow: ellipsis
64 }

 

这种情况及时配置的图片有点小误差,我们也可以忽略。

使用优化方案后,当图片加载不出来的时候,容器的位置不会消失,如下图:

那么对于体验上来说,整个页面不会在图片加载的时候出现撑高的情况。

 

解决方案代码演示:https://jsfiddle.net/boxiang_hbx/wrf4xshn/3/

当前两张图没有load出来的时候,代码演示:https://jsfiddle.net/boxiang_hbx/wrf4xshn/4/

 

改优化方案可以巧妙地用于其他布局的地方,不限于图片,有问题,欢迎讨论!

 

尊重版权,转载请说明出处!

 

目录
相关文章
|
12小时前
|
运维 Kubernetes 测试技术
容器技术:优化软件测试流程的利器
本文介绍了容器技术的概念、优势和历史发展,对比了容器与虚拟机的区别,并提及了Docker和Kubernetes等常见容器技术。容器作为轻量级虚拟化工具,提供高效、灵活的应用部署方式,广泛应用于软件开发、云计算和微服务架构。随着技术演进,容器将在边缘计算、人工智能等领域发挥更大作用,推动行业变革。
8 3
|
3天前
|
缓存 关系型数据库 数据库
【Docker 专栏】Docker 与容器化数据库的集成与优化
【5月更文挑战第9天】本文探讨了Docker与容器化数据库集成的优势,如快速部署、环境一致性、资源隔离和可扩展性,并列举了常见容器化数据库(如MySQL、PostgreSQL和MongoDB)。讨论了集成方法、注意事项、优化策略,包括资源调整、缓存优化和监控告警。此外,强调了数据备份、恢复测试及性能评估的重要性。未来,随着技术发展,二者的集成将更紧密,为数据管理带来更多可能性。掌握此技术将应对数字化时代的机遇与挑战。
【Docker 专栏】Docker 与容器化数据库的集成与优化
|
4天前
|
前端开发
css设置内嵌样式阴影
css设置内嵌样式阴影
8 0
|
12天前
|
前端开发 UED 开发者
【专栏:HTML与CSS实战项目篇】制作一个响应式图片画廊
【4月更文挑战第30天】本文介绍了如何使用HTML和CSS创建响应式图片画廊。响应式画廊能根据用户设备屏幕大小自动调整布局。首先规划结构,包含一个图片容器和每张图片元素,并为图片提供替代文本。接着设计样式,设置图片大小、间距和视觉效果。然后通过媒体查询实现响应式设计,根据不同屏幕尺寸调整图片排列。同时考虑性能优化,如压缩图片和使用懒加载技术。最后,测试和调试确保画廊在各种设备上正常工作。这个过程强调了响应式设计和用户体验的重要性。
|
12天前
|
编解码 移动开发 前端开发
【专栏:HTML与CSS移动端开发篇】使用Viewport Meta标签优化移动端显示
【4月更文挑战第30天】本文介绍了HTML的Viewport Meta标签在移动端网页优化中的作用。Viewport Meta标签定义了视口属性,如宽度、高度、初始缩放等,解决移动设备因屏幕尺寸差异导致的显示问题。主要属性包括width(常用device-width)、initial-scale、maximum-scale、minimum-scale和user-scalable。
|
12天前
|
前端开发 UED
【专栏:工具与技巧篇】CSS Sprites 与图标字体:优化网页图标加载
【4月更文挑战第30天】本文探讨了网页图标优化的两种方法:CSS Sprites和图标字体。CSS Sprites通过合并图标减少HTTP请求,提高加载速度,但维护复杂;图标字体则提供良好扩展性和定制性,易于调整大小和颜色。两者各有优劣,适用于不同场景。在实际应用中,应结合使用,根据项目需求灵活选择,以实现最佳性能优化和用户体验。
|
13天前
|
前端开发 UED 开发者
【专栏】探讨了CSS3动画卡顿的原因,包括复杂动画效果、过多元素参与、低效代码结构和硬件资源限制,并提出优化措施
【4月更文挑战第29天】本文探讨了CSS3动画卡顿的原因,包括复杂动画效果、过多元素参与、低效代码结构和硬件资源限制,并提出优化措施:简化动画路径、控制元素数量、优化代码结构、利用硬件加速及性能监测。通过实际案例展示了优化效果,强调了性能优化对提升用户体验的重要性。在开发中,应持续关注并优化动画性能,以适应网页应用的需求。
|
19天前
|
前端开发 JavaScript
css 设置div阴影样式
css 设置div阴影样式
23 0
|
19天前
|
前端开发 JavaScript
css 设置无背景色
css 设置无背景色
25 1
|
23天前
|
缓存 前端开发 JavaScript
《CSS 简易速速上手小册》第8章:CSS 性能优化和可访问性(2024 最新版)
《CSS 简易速速上手小册》第8章:CSS 性能优化和可访问性(2024 最新版)
25 0