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

需求

我们在做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/

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

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

时间: 2024-10-22 13:51:45

css体验优化之图片容器设置宽高比的相关文章

get新技能: 如何设置元素高度与宽度成特定比例。宽度改变,高度自动按比例改变。 例如设置宽高比16:9。

设置宽高比在很多时候是有用的. 下面的栗子,我们设置一个容器的宽高比为16:9 //HTML代码片段 <div class="container"> <div class="wrapper"> <div class="content">content</div> </div> </div> //css 代码 div{ border: 1px solid green; } .c

c# winform DirectX播放器 可以任意设置宽高比 屏幕拉伸

第一步:dll引用 Microsoft.DirectX.dll Microsoft.DirectX.AudioVideoPlayback.dll 如果没有的话,可能需要安装微软的DRECTX JDK directx支持的视频文件格式: (*.avi; *.mov; *.mpg; *.mpeg; *.ts; *.wmv; *.vob; *.dat; *.rm; *.rmvb; *.flv)|*.avi; *.mov; *.mpg; *.mpeg; *.ts; *.wmv; *.vob; *.dat

巧用padding让图片宽高比固定并自适应布局

1.从上图知道原始图片大小是 800 * 250,即宽高比为 3.2: 2.html 及 css 代码如下, 可以知道就只是在一个div里面放了一张图片,那么如何让这张图片的宽高比固定呢,看了css之后就知道了原来是神奇的padding帮了我们的忙. 3.当img的宽度为100%时,那么.banner的padding-bottom(padding-top也可以)的值为 100%(图片想要设置的宽度) / 3.2(图片的原始宽高比)= 31.25%: (如果你想把 img 的宽度设为50%的话,那

加载的过程中图片变形了? --教你自定义自动适配图片宽高比的RatioLayout

很多同行在开发中可能会遇到这样的问题,就是在加载图片的时候会出现图片变形的问题.其实这很可能就是你的图片宽高比和图片所在容器的宽高比不匹配造成的.比如说图片的宽为200,高为100.宽高比就是2,那么这时候把它放在宽高比为1或者3的控件上就会分别出现变窄和变宽的问题.只有在容器宽高比为2的时候图片才会和原始显示效果一样.怎样解决这个问题呢?这个时候就可以创建一个能够自适应图片宽高比的父容器来包裹ImageView就可以了.在使用RatioLayout的时候要注意以下几点: 1)ImageView

使用css让动态容器按固定宽高比显示

需求:页面上有一个div的宽度是随着屏幕宽度的改变而改变的,但其宽高比始终是2:1,也就是当宽度是1000px时,高度为500px 分析:无论浏览器窗口如何改变,始终要让目标元素的宽高比保持2:1,我们第一个想到的可能是使用js来实现,但是使用js来实现往往会比较耗费性能,那么今天我们就来讲下使用css来完成这个需求. 实现:作为"码农"我们还是直接上代码来得直观一点! html: <body> <div class="container">

手机端上传未知图片大小,js设置宽高比例

<style rel="stylesheet" type="text/css"> .lunboimg{ width: 100%; height: auto; float: left;}.lunboimg img{ width: 100%; float: left;} </style> $(function(){ var evt = "onorientationchange" in window ? "orient

Web性能优化:图片优化

程序员都是懒孩子,想直接看自动优化的点:传送门 我自己的Blog:http://blog.cabbit.me/web-image-optimization/ HTTP Archieve有个统计,图片内容已经占到了互联网内容总量的62%,也就是说超过一半的流量和时间都用来下载图片.从性能优化的角度看,图片也绝对是优化的热点和重点之一,Google PageSpeed或者Yahoo的14条性能优化规则无不把图片优化作为重要的优化手段,本文覆盖了Web图片优化的方方面面,从基本的图片格式选择.到尚未被

CSS规范 - 优化方案

值缩写 缩写值可以减少CSS文件大小,并增加可读性和可维护性. 但并非所有的值都必须缩写,因为当一个属性的值缩写时,总是会将所有项都设置一遍,而有时候我们不希望设置值里的某些项. /* 比如我们用下面这个样式来让某个定宽的容器水平居中,我们要的只是left和right, * 而top和bottom不是这个样式要关心的(如果设置了反倒会影响其他样式在这个容器上的使用), * 所以这时我们就不需要缩写 */ .f-mgha{margin-left:auto;margin-right:auto;} /

APP弱网络条件下,体验优化之道

APP弱网络条件下,体验优化之道 最近跟朋友聊天刚好聊到这一块,他们是在做电商业务,商品图片及其多,API接口请求频率也高.然而,他们在移动2/3G的网络环境下,APP经常会出现Loading很久的情况,这里我把我们所分析与使用到的网络优化方案与大家分享一下. 所谓的弱网络,也就是指在网络不好的条件下进行使用APP,如2G.3G网络,这类网络条件下,用户的网络速度基本维持在10K/S~60K/S.如此差的网络环境, 如果还希望给用户提供良好的用户体验,那么我们的APP就该想想如何优化了. 转载表