前端开发者学堂 - fedev.cn

CSS制作图片水平垂直居中

发布于 大漠

做为一个前端设计人员,对于产品展示页面的设计一定不会陌生,其中产品图片摆放是必定经历的一步,并且水平居中和垂直居中又是最多的。有时需要产品图片水平垂直居中显示,这种展示用CSS来实现又是比较棘手的一件事,我想很多前端攻程师都有研究过或者说是搜索过这些方法吧。很多网站都是使用table来实现产品图片垂直居中,实现也是相当的方便,唯一不足之处就是结构繁锁,那么今天和大家一起看几种不是使用talbe方法实现产品图片水平垂直居中的方法。

曾经拜读过张鑫旭-鑫空间-鑫生活写的《大小不固定的图片、多行文字的水平垂直居中》一文,从中学会好几种关于图片水平垂直居中的方法,而今天我要和大家一起探讨的是其他几种关于图片水平垂直居中的方法。

图片水平垂直居中存在的问题

所谓的图片水平垂直居中就是把图片放在一个容器元素中(容器大于图片尺寸或是指定了大小的容器),并且图片位居此容器正中间(中间是指元素容器的正中间),而图片不是以背景图片(background-image)形式展示,是以<img>元素形式展示的。如下图所示:

大家都知道,如果其中img有明确的尺寸,并且图片尺寸都是一致的,要实现其水平垂直居中一件非常容易的事情,我们只要像下面操作就能方便解决问题:

  1. 将图片以块元素方式显示(display:block);
  2. 给图片指定明确的margin-left和margin-top值,而其中margin-left值等于图片所在容器的宽度(imbBoxWidth)减去图片本身宽度(imgWidth)的值的一半【margin-left=(imgBoxWidth-imgWidth)/2】;margin-top值和margin-left很类似,只是把相对应的宽度值换成高度值,即【margin-top=(imgBoxHeight-imgHeight)/2】。

上面的方法是方便简单,但受限太大,比如说图片不一样时,用上面的方法实现就比较难,或许你会说给相图尺寸的图片定义一个类,然后在给他们指定不同的margin。但有很多情况下我们是无法使用这种方法来解决图片水平垂直居中的问题,比如说有很多不同尺寸的图片,而且图片容器的单位和图片大小单位不一致时,这样我们就没有办法能计算出图片与容器之间的margin是多少,此时解决图片水平居垂直居中就相当的困难。换过来说,如果有什么办法能让不同尺寸的图片实现水平垂直居中,那对于我们来说是多么有用的,又是多么方便的一件事。

解决问题——让图片水平垂直居中

解决水平居中是相当的容易,如果图片左浮动并且"display:inline"时,我们只要给图片设置一个"text-align:center"属性,就顺利解决了水平居中。

对于垂直居中的最佳解决方案,在现代浏览器中,我们可以给图片容器设置“dipslay:table-cell;vertical-align:middle”, 这种方法能顺利的让图片实现垂直居中,但只能在现代浏览器运行,在IE6-7中无法正常运。这样一来是不是将无法实现呢?大家别急,我们一起来看下面的几种方法:

1、table-cell加上display:inline

这种方法很神奇,前面我们说过用display-table和vertical-middle是在现代浏览器中实现图片垂直居中是最佳办法,只是IE6-7不支持display:table-cell,其实并不是那么严重,我们只要在IE6-7下给他来个另外的写法。其实掌握了原理在IE下实现起来也并不难,下面我们一起先来看看这个思路:

  1. 首先在图片的容器元素中设置“display:table-cell;vertical-align:middle;”实现现浏览器的垂直居中;
  2. IE6-7有一个好的办法,就是创建一个线盒,此线盒的高度和图片容器的高度一样,并且给这个线盒也设置“vertical-align:middle”。

接下来的关键是给IE6-7创建线盒,还好IE6-7下部分显示支持“dipslay:inline-block”。这样我们就可以在图片的容器中创建一个空元素(比如说span),并且设置span的“display:inline-block;height:100%;vertical-align:middle”。

创建线盒中有一个细节需要注意,在IE6-7中空的line-block元素宽度为“0”,这样在IE6-7下是没有效果的,此时我们需要给span加上“width:1px”,此时会给水平居中造成1px的误差,但这种bug你是可以接受得了的。

那么最终解决方案就是使用display:table-cell和设置了display:inline-block的线合span。当然其中还是需要为IE写一点特殊的代码,接下来我们的起来看代码:

HTML Markup

			<ul class="imgWrap clearfix">
				<li><a href="#" class="imgBox"><span></span><img src="images/img1.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img2.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img3.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img4.jpg" alt="" /></a></li>
			</ul>
		

CSS Code

			<style type="text/css">
				.imgWrap li {
					float: left;
					border: solid 1px #666;
					margin: 10px 10px 0 0;
					list-style: none;
					border-collapse: collapse; 
				}
				.imgWrap a {
					background: #ffa url(images/gridBg.gif) repeat center;
					width: 219px;
					height: 219px;
					display: table-cell;/*图片容器以表格的单元格形式显示*/
					text-align: center; /* 实现水平居中 */
					vertical-align: middle; /*实现垂直居中*/					
				}
				.imgWrap a:hover {
					background-color: #dfd;
				}
				.imgWrap img {
					border: solid 1px #66f;
					vertical-align: middle; /*图片垂直居中*/
				}
				</style>
				<!--下面是解决IE6-7的正常显示的代码-->
				<!--[if lt IE 8]>
					<style type="text/css">
					.imgWrap a {
						display: block;
					}
					.imgWrap span {
						display: inline-block;
						vertical-align: middle;
						height: 100%;
					}
					.imgWrap {
						_height: 0;
						zoom: 1;
					}
					</style>
				<![endif]-->
		

效果

2、空白标签实现图片的垂直居中

这种方法很有意思,也很有独特之处,我的思路也是来自于张鑫旭-鑫空间-鑫生活写的《大小不固定的图片、多行文字的水平垂直居中》一文中的使用空白图片实现垂直对齐。他主要使用了一张宽度为1px高度为100%的透明图片,并设置图片“vertical-align:middle”。后来我想了想,此处能不能不使用图片,直接像上面的实例一样,用一个空格的span标签,只是将其“display:inline”设置为“display:inline-block”。因为这两者的核心原理都是一致的:我将span行内元素设置为行内块元素,也就是将其display设置为“inline-block”,将其宽度定位1px,height为容器的100%,这样高度可以和容器的高度达到一样,然后通过“vertical-align:middle”设置垂直对齐,从而实现所需要的效果。因为张鑫旭-鑫空间-鑫生活写的《大小不固定的图片、多行文字的水平垂直居中》一文中的使用空白图片实现垂直对齐成功实现效果,于是我也按自己的思路动手一试,效果和他的一模一样,而且兼容各浏览器,代码较第一种方法又简单很多,最主要的不要单独给IE写效果,而且易懂,下面一起看看这种方法吧。

HTML Markup

			<ul class="imgWrap clearfix">
				<li><a href="#" class="imgBox"><span></span><img src="images/img1.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img2.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img3.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><span></span><img src="images/img4.jpg" alt="" /></a></li>
			</ul>
		

CSS Code

			<style type="text/css">
				.imgWrap li{ 
					width: 219px;
					height: 219px;
					float: left;
					border: solid 1px #666;
					margin: 10px 10px 0 0;
					list-style: none;
					text-align: center;
					font-size: 0;
				}

				.imgWrap a {
					display: block;
					height: 100%;
					background: #ffa url(images/gridBg.gif) repeat center;
				}
				.imgWrap a:hover {
					background-color: green;
				}
				.imgWrap span {
					display: inline-block;/*将行内元素改变为行内块元素显示*/
					width: 1px;/*实现IE下可读效果*/
					height: 100%;/*使用元素高度和图片容器高度一样*/
					vertical-align: middle;/*垂直对齐*/
				}

				.imgWrap img {
					vertical-align: middle;
				}
			</style>
		

效果

3、display:table模拟表格实现图片垂直居中

接下来要说的这种方法是结构有点复杂,而且在IE6-7事要配合hack来产现。这个方法就是模拟表格的形式来实现图片垂直居中的效果。

表格大家都知道,他有行(table-row)单元格(table-cell),众所周知,表格单元格中“vertical-align: middle”能让元素垂直居中,那么下面这个实例就是利用这种原理来制作的,一起来看代码

HTML Markup

			<ul class="imgWrap clearfix">
				<li>
					<div class="table">
						<div class="tableCell">
							<a href="#" class="imgBox"><img src="images/img1.jpg" alt="" /></a>
						</div>
					</div>	
				</li>
				<li>
					<div class="table">
						<div class="tableCell">
							<a href="#" class="imgBox"><img src="images/img2.jpg" alt="" /></a>
						</div>
					</div>	
				</li>
				<li>
					<div class="table">
						<div class="tableCell">
							<a href="#" class="imgBox"><img src="images/img3.jpg" alt="" /></a>
						</div>
					</div>	
				</li>
				<li>
					<div class="table">
						<div class="tableCell">
							<a href="#" class="imgBox"><img src="images/img4.jpg" alt="" /></a>
						</div>
					</div>	
				</li>
			</ul>	
		

CSS Code

			.imgWrap li {
				background: #ffa url(images/gridBg.gif) repeat center;
				width: 219px;
				height: 219px;
				float: left;
				border: solid 1px #666;
				margin: 10px 10px 0 0;
				list-style: none;
				text-align: center;
			}
			.table {
				width: 100%;
				height: 100%;
				display: table;
				position: relative;
			}		

			.tableCell {				
				display: table-cell;
				vertical-align: middle;
				text-align: center;			
				padding: 10px;
				*position: absolute;
				*top: 50%;
				*left: 50%;
			}
			.imgWrap a {
				display: block;
				*position:relative;
				*top: -50%;
				*left: -50%;
			}
		

效果

4、jQuery方法实现图片居中

这个方法很简单,就是得用jQuery方法,将图片转换为其父元素的背景图片,并且在其父元素中居中显示背景图片,然后在将其自身的透明度设置为“0”, 这样也能达到图片居中的效果。

Html Markup

			<ul class="imgWrap clearfix">
				<li><a href="#" class="imgBox"><img src="images/img1.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><img src="images/img2.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><img src="images/img3.jpg" alt="" /></a></li>
				<li><a href="#" class="imgBox"><img src="images/img4.jpg" alt="" /></a></li>
			</ul>	
		

CSS Code

			.imgWrap li {
				float: left;
				border: solid 1px #666;
				margin: 10px 10px 0 0;
				list-style: none;
				background: #ffa url(images/gridBg.gif) repeat center;
			}
			.imgWrap a {
				width: 219px;
				height: 219px;
				display: block;
			}
		

jQuery Code

			//先写一个小插件
			$.fn.imgVAlign=function(){
				return $(this).each(function(i){
					//获取图片的src值,并定义给变量bg
					var bg = $(this).attr("src");
					//给图片的父元素定义背景图片的样式,并且背景图片
					$(this).parent().css({"background": "url("+ bg +") no-repeat center center"
					});
					//将图片隐藏
					$(this).css("opacity","0");
				});
			}
			//调用上面写的插件
			$(document).ready(function(){
				$(".imgBox img").imgVAlign();
			});
		

效果

上面主要介绍了四种常用的有关于图片水平垂直居中的方法,其实还有很多别的方法,比如说在《CSS制作水平垂直居中对齐》介绍了八种实现水平垂直居中的效果,其实那些方法都可以运用到图片的水平垂直居中,感兴趣的同学可以自己去尝试一下。那么有关于图片的水平垂直居中介绍就说到这里了。希望这些方法在你平时制作Web页面效果时有所帮助,这样我会感到很高兴,如果你有新的创意或者有更好的方法,可以直接留言分享。

如需转载烦请注明出处:W3CPLUS

nike air max 1 infrared