html图片只固定高度,CSS让高度不确定图片垂直居中的几种技巧

在网页设计过程中,有时候会希望图片垂直居中的情况。而且,需要垂直居中的图片的高度也不确定,这就会给页面的布局带来一定的挑战。下面总结了一下,曾经使用过的几种方法来使图片垂直居中,除了第一种方法只限于标准浏览器外,另外两种方法的兼容性还不错。

方法一将外部容器的显示模式设置成display:table,这个设置的意思不用多说了吧… img标签外部再嵌套一个span标签,并设置span的显示模式为display:table-cell,这样span内部的内容就相当于表格,可以很方便的使用vertical-align属性来对齐其中的内容了。

复制代码代码如下:

方法1 - 未知高度的图片垂直居中 - www.nowamagic.net

body {

height:100%;

}

#box{

width:500px;height:400px;

display:table;

text-align:center;

border:1px solid #d3d3d3;background:#fff;

}

#box span{

display:table-cell;

vertical-align:middle;

}

#box img{

border:1px solid #ccc;

}

方法二

标准浏览器的情况还是和上面一样,不同的是针对IE6/IE7利用在img标签的前面插入一对空标签的办法。

复制代码代码如下:

方法2 - 未知高度的图片垂直居中 - www.nowamagic.net

body {

height:100%;

}

#box{

width:500px;height:400px;

display:table-cell;

text-align:center;

vertical-align:middle;

border:1px solid #d3d3d3;background:#fff;

}

#box img{

border:1px solid #ccc;

}

方法三

在img标签外包裹一个p标签,标准浏览器利用p标签的伪类属性:before来实现居中,另外,对于IE6/IE7使用了CSS表达式来实现兼容。

复制代码代码如下:

方法3 - 未知高度的图片垂直居中 - www.nowamagic.net

body {

height:100%;

}

#box{

width:500px;height:400px;

text-align:center;

border:1px solid #d3d3d3;background:#fff;

}

#box p{

width:500px;height:400px;

line-height:400px; /* 行高等于高度 */

}

/* 兼容标准浏览器 */

#box p:before{

content:"."; /* 具体的值与垂直居中无关,尽可能的节省字符 */

margin-left:-5px; font-size:10px; /* 修复居中的小BUG */

visibility:hidden; /*设置成隐藏元素*/

}

#box p img{

*margin-top:expression((400 - this.height )/2); /* CSS表达式用来兼容IE6/IE7 */

vertical-align:middle;

border:1px solid #ccc;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值