前端开发者学堂 - fedev.cn

CSS美化图片

发布于 大漠

很久没有写blog了,不知道是时间太紧的原故还是人懒惰了。今天在webdesignerwall.com看到一篇不错的文章《CSS Decorative Gallery》,文章中介绍了多种不同的方法,用于美化Web页面中的IMG。学得很有意思,其实早在《CSS3制作图片样式》和《jQuery和CSS3给图片制作圆角》中有介绍过怎么美化img,但是今天这篇文章更有意思。我们不仿一起来看看:

如果你阅读了webdesignerwall.com写的文字渐变一文,理解后面的内容就很简单。因为后面的DEMO都采用了同样的原理。这原理很简单就是给元素添加一个额外的标签,比如说<span>,将背景图片放在这个标签上,然后将其当作图片的朦板,遮盖在图片上。这样制作给你带来极大的灵活性,可维护性。当然,如果你不需要兼容IE低版本的话,我们不用增加任何标签也可以制作,就是使用CSS3选择器中的伪类(:before和:after)或者伪元素(::before和::after),同时把放在span标签上的背景图片放在伪元素或伪类上。这是一种新的思路,不过此文并没有运用,我还是按照原作者的思路与大家一起学习其制作方法。

制作原理:

其实原理前面就多了,在此重复一下:添加一个额外标签,充当图片的朦板,然后将图片边框之类背景放在这个标签上。当然在CSS3中,可以不添加标签,直接使用伪类或伪元素来实现。

demodownload

技巧的好处是什么?

大家会问,这样做能给我们带来什么好处呢?其实好处还是蛮多的:

  1. 节约时间:你不用为每种效果制作图片,然后将图片导出来;
  2. 保持原图片不变:使用这种方法,无需为了不同的效果去改为源图片;
  3. 适应多主题:这种技巧最大的好处就是,我们可以随时根据需要,使用css就能制作出不同的主题效果;
  4. 能工作在任何网站上:这种技巧不受限于网站的类型,而且图片大小不限;
  5. 兼容各浏览器:具有较强的兼容性,连IE6这样的低版本都能兼容。

基本结构:

结构是很简单,如:

<div class="photo">
  <a href="">
    <span></span>
      <img src="xxx.jpg" alt="" />
    </a>
  </div>

上面的结构我想大家都懂的,不过我还是在多说一下,我们把图片放在一个“div.photo”中,正如前面所说,在这里面添加了一个“span”标签(当然你可以是其他的标签),这个标签主要是充当图片的朦板效果,将图片的边框图片之类放在这个“span”中(以背景图片方式展示)。当然你如果不想添加这个“span”也行,你可以使用“:before”和“::before”之类,只不过这种方法只能在现代浏览器下运行。或者说,你可以使用js来插入这个“span”标签,正如前面的《CSS3制作图片样式》和《jQuery和CSS3给图片制作圆角》所介绍的一样。

朦板图片有着落放置了,接下来就是使用样式,我们这个“span”标签进行绝对定位,并且让其遮盖在原图上,其工作方式,我们以下图来进说简单明了的说明:

IE6下的PNG问题

由于我们的朦板图片采用的格式是PNG24(或者PNG32)的透明图片,这样在IE6下会有一个透明层的BUG,为了解决这个BUG,可以使用iepngfix.htc。使用iepngfix.htc并不复杂,你只需要把“iepngfix.htc”下载到你的项目中,然后在你项目文件的“<head>”中插入以下代码:

<!--[if lt IE 7]>
  <style type="text/css">
    .photo span { behavior: url(iepngfix.htc); }
  </style>
<![endif]-->

除了使用这种方法之外,你也可以使用DD_png的方法(js脚本处理方法)来解决PNG透明问题,详细的您可以参阅《解决IE6的png透明问题》一文。

效果预览:

说了这么多,那真的是不是那么神奇有用呢?我们在具体每个demo化之前,先来看一个DEMO效果:

jQuery插入标签:

对于有代码洁癖的同学来说,他不能容忍在HTML有任何空标签,那么此时,我们要满足这些同学的要求,只好借助JQ来实现:

<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript">
  $(document).ready(function(){						   
    //动态插入图片朦板空标签span
    $(".photo a").prepend("<span></span>");								  
  });
</script>

DEMO分析

理论上的东西我想大家应该了解的差不多了,接下来,我们来看webdesignerwall.com制作的几个DEMO,这里我分别将其代码扣出,放上来与大家分享,希望对大家有所帮助:

在具体DEMO前,先将其结构放上来,由于我们DEMO中不只一张图片,所以将前面示例的结构换成了列表的形式,后面的DEMO中如无特殊声明,都以下面的结构为基础:

<ul class="gallery">
  <li><a href="#"><span></span><img src="images/11.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/14.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/4.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/7.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/5.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/6.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/3.jpg" alt="image" /></a></li>
  <li><a href="#"><span></span><img src="images/1.jpg" alt="image" /></a></li>
</ul>

注:每个DEMO会有细微上的差别,请以相对应的DEMO源文件为标准。

1、Simple Gallery

第一个DEMO是比较简单,我们在span上使用一张(类似于胶带的背景图)“tape.png”,将图片制作成类似于粘贴在墙上的效果:

CSS Code

/*清除浮动*/
.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	margin: 10px;
	padding: 0;
	float: left;
	position: relative;
	width: 180px;
	height: 130px;
}
.gallery img {
	background: #fff;
	border: solid 1px #ccc;
	padding: 4px;
}
/*图片朦板效果*/
.gallery span {
	width: 77px;
	height: 27px;
	display: block;
	position: absolute;
	top: -12px;
	left: 50px;
	background: url(images/tape.png) no-repeat;
}
.gallery a {
	text-decoration: none;
}

大家在实际运用中可以根据自己需要进行相对应的调整。这里说一下,其实“tap.png”的效果,如果在CSS3中的话,大家可以直接使用CSS3代码制作实现,如果你有兴趣了解如何制作?可以移步这里!

2、Mini Icons

这个效果和DEMO一是很相似的,只是将span的背景图片换成了小的icon,同时鼠标移到图片上后,ICON也会做一定的变化,这种效果可以说,很多地方可见:

CSS代码

.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	margin: 10px;
	padding: 0;
	float: left;
	position: relative;
	width: 180px;
	height: 130px;
}
.gallery img {
	background: #fff;
	border: solid 1px #ccc;
	padding: 4px;
}
/*ICON容器大小与定位*/
.gallery span {
	width: 20px;
	height: 18px;
	display: block;
	position: absolute;
	bottom: 10px;
	right: 10px;
}
/*不同类型运用不同的ICON背景图片*/
.gallery .favorite {
	background: url(images/favorite.gif) no-repeat;
}
.gallery .photo {
	background: url(images/photo.gif) no-repeat;
}
.gallery .video {
	background: url(images/video.gif) no-repeat;
}
.gallery a {
	text-decoration: none;
}
.gallery a:hover img  {
	border-color: #666;
}
.gallery a:hover span {
	background-position: left -22px;
}

注:与DEMO一相比,需要在对应的a标签上添加类名,详细以DEMO源文件为标准。

3、Photo With Text

DEMO3与前两上相比,从结构上来说,把“span”标签更换成“em”标签,其实不用更换也能做出下面的效果,另外还在“em”标签中添加了图片对应的标签,并且在这个“em”上制作了一种带有纹理的背景,如下所示:

.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	padding: 10px;
	margin: 0;
	float: left;
	position: relative;
	width: 180px;
	height: 130px;
}
.gallery li:hover img {
	border-color: #000;
}
.gallery img {
	background: #fff;
	border: solid 1px #888;
	padding: 5px;
}
/*朦板效果*/
.gallery em {
	background: #fff url(images/grey-gradient.gif) repeat-y;
	color: #000;
	font-style: normal;
	padding: 2px 10px;
	display: block;
	position: absolute;
	top: 110px;
	left: 9px;
	border: 1px solid #999;
	border-left-color: #888;
}
.gallery a {
	text-decoration: none;
}
.gallery a:hover em {
	background: #ffdb01 url(images/orange-gradient.gif) repeat-y;
	border-color: #c25b08;
}

4、Popup Text

这个效果大家也有看到过,就是鼠标移到图片上,有一个简单的提示说明文字,如下所示:

CSS 代码:

.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	padding: 10px;
	margin: 0;
	float: left;
	position: relative;
	width: 180px;
	height: 130px;
}
.gallery img {
	background: #fff;
	border: solid 1px #ccc;
	padding: 5px;
}
.gallery li:hover img {
	border-color: #999;
}
/*朦板效果,并且默认时隐藏*/
.gallery em {
	width: 102px;
	background: url(images/bubble.gif) no-repeat;
	padding: 3px 0 6px;
	display: none;
	position: absolute;
	top: -2px;
	left: 50px;
	font-style: normal;
	text-align: center;
}
.gallery a {
	text-decoration: none;
	color: #000;
}
/*鼠标悬浮时,朦板显示*/
.gallery a:hover em {
	display: block;
}

5、Mini Paper Clip

使用一个别针一样的背景图片,制作出图片别在另一个纸张上的效果,与前面demo不同之处,添加了两个标签,其中span上放别针背景,em放描述文字:

CSS代码

.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	padding: 10px;
	margin: 0;
	float: left;
	position: relative;
	width: 180px;
	height: 130px;
}
.gallery li:hover img {
	border-color: #000;
}
.gallery img {
	background: #fff;
	border: solid 1px #ccc;
	padding: 5px;
}
/*描述文字定位*/
.gallery em {
	background: #fff;
	color: #000;
	font-style: normal;
	padding: 2px 8px 0 22px;
	display: block;
	position: absolute;
	top: 20px;
	left: 5px;
	border: 1px solid #999;
}
.gallery a {
	text-decoration: none;
}
/*别针朦板效果*/
.gallery span {
	width: 30px;
	height: 60px;
	display: block;
	position: absolute;
	top: 7px;
	left: 9px;
	background: url(images/paper-clip-mini.png) no-repeat;
	z-index: 3;
}

6、Art Gallery

使用不较大的朦板背景图片,可以给图片添加一些艺术边框效果,如:

CSS 代码

.gallery:after,
.gallery:before {
	display: table;
	content:"";
}
.gallery:after {
	clear:both;
	overflow: hidden;
}
.gallery {
	list-style: none;
	margin: 0;
	padding: 0;
	zoom:1;
}
.gallery li {
	margin: 20px;
	padding: 0;
	float: left;
	position: relative;
	width: 212px;
	height: 175px;
}

.gallery a {
	text-decoration: none;
	color: #666;
}
.gallery a:hover {
	color: #000;
	text-decoration: underline;
}
.gallery img {
	padding: 20px 0 0 21px;
}
/*艺术相框效果*/
.gallery em {
	width: 216px;
	background: url(images/gold-frame.png) no-repeat;
	display: block;
	position: absolute;
	top: -2px;
	left: -2px;
	text-align: center;
	font: 100%/100% Georgia, "Times New Roman", Times, serif;
	padding-top: 168px;
}

使用不同的边框效果,我们可以制作出不一样的DEMO,只要你有创意,什么效果都可以制作出来,为了节省你的时间,我就不全部列出来了,如果你喜欢其他的效果,你就拼命点这里

上面方法采用的是列表形式,可能在您布局之时会碰到同一行末尾的margin-right问题,说得简单点就是末位会掉下去,这里我没有做过多处理,如果你想完美点,可以参考《如何避免重复列末尾的Margin》一文,或者参阅为之为大家总结的《CSS解决方案》中的《项目列表解决方案》。

有关于CSS美化图片就介绍到这里了,这里只是给大家提供一个思路,您可以发挥你的创意,和无限的想像力,制作出各式各样的,具有创意的效果。

特别声明,本文中的图片和代码均来自于webdesignerwall.com的《CSS Decorative Gallery》一文。

demodownload

如需转载,烦请注明出处:https://www.fedev.cn/css/css-decorative-gallery.html

nike free run 5.0 womens