论坛首页 入门技术论坛

CSS实现很酷的透明样式(附效果图)

浏览 12851 次
精华帖 (0) :: 良好帖 (5) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-05-20   最后修改:2009-05-20

精灵空间不少地方都有很酷的透明效果。可以先看这个演示: 精灵 部落 (下面附上几个截图效果)。

首页

 

 

精灵空间

 

 

背景音乐和网页收藏

 

 

图片浏览和图片收藏

 

 

视频播放和视频收藏

如果你对图片保存格式有些了解的话,你会发现 gif图片是可以保留部分透明效果的,在网页中直接使用 gif图片的话,可以部分透明,但效果并不完美,比如图片边沿不整齐,不能半透明等等。实际上,还有一种网页中很常用的 .png格式的图片可以很完美的保存图片的透明效果。在 ps中设计出来的各种透明半透明效果,只要你正确的将它保存为 .png格式的话,图片打开的效果几乎和在 ps中是一样的,边沿很光滑,透明度也都一致。我们今天这里不重点讨论怎么制作带有透明效果的 .png格式图片,我们来讨论怎么让它在网页中完美的显示出它的透明的魅力。

也许也有朋友尝试过要做出一些透明的效果,也有朋友知道 .png图片可以是有透明效果的,但是怎么一放到网页里面,显示的效果就变味了呢?

事实上, firefox是可以直接完美的支持 .png图片的透明效果的。不信朋友们现在就可以试试,在网页里面插入任何一个带有透明效果的 .png图片,用 firefox打开。

只可惜,现在毕竟还是使用 ie的同志占多数。偏偏 ie里面不能直接出这种效果。但肯定是有办法解决的。我们知道 ie是支持滤镜的。也许不少朋友也知道滤镜可以做一些很不错的效果出来,但也许你不是很了解“ AlphaImageLoader ”这个滤镜。它起的作用就是在 html dom元素的背景和内容之间的导入一层图片。如果这个图片是带有透明样式的 .png图片,它将完美的保留其透明样式,并且在完全透明的部分,是鼠标可穿透的。

我们来看一个在 ie里面的完整的透明样式定义:

background-color : transparent ;

background-image : none ;

filter : progid:DXImageTransform.Microsoft.AlphaImageLoader(src="test.png", sizingMethod="crop") ;

 

首先,你要把样式的背景颜色和背景图片都设置为没有。然后用滤镜导入一个 .png图片,原则上就 ok了,其实也很简单。

 

当然我们不能只顾 ie里面如何。一般情况下,我们还需要考虑如何兼容 firefox。上面已经说过了,在 firefox里面其实是可以直接兼容 .png的透明格式的,所以这里更简单:

width : 16px ;

height : 42px ;

background : transparent url(images/Red_03.png) no-repeat ;

 

下面综合起来看这个兼容的样式应该怎么写:

. Transparent {

width : 16px ;

height : 42px ;

background : transparent url(images/transparent.png) no-repeat ;

}

 

* html . Transparent {

background-color : transparent ;

background-image : none ;

filter : progid:DXImageTransform.Microsoft.AlphaImageLoader(src=images/ transparent.png", sizingMethod="crop") ;

}

为什么这样可以兼容呢?

首先我们看,.Transparent这个样式本身就是兼容firefox的。而后面的* html这个符号只有ie可以识别,熟悉样式兼容的朋友肯定经常用到这个写法。那么* html . Transparent在ie里面就将覆盖或者添加样式的属性,实现透明效果。有兴趣的朋友,不防一试。

文章来自:精灵 部落

QQ:70buluo@163.com(1047166052)

   发表时间:2009-06-11  
美工强大啊!不过用来干什么呢?!
0 请登录后投票
   发表时间:2009-06-12  
在IE7-下,由于大量使用滤镜,这种效果在项目中如果频繁调用,特别是如果还涉及透明窗口拖拉、缩放等效果,则渲染效率是个非常严重的问题,往往会导致用户体验极差。

如果你还考虑这些用户(占有率还很高),基本就放弃了。当然少数弹出调用,改善一下视觉体验,应该没什么问题。

原生支持png32透明的浏览器应该没太大的渲染效率问题,但是也得用好。
0 请登录后投票
   发表时间:2009-06-13   最后修改:2009-06-13
很强大,全部自己实现?没看到引入其他库,

提些细节问题:
1.window 常常 窗体头出现在 浏览器边界外,关闭按钮图片不够清晰,模糊??
2.console 调试信息还在上面。。。。
3.不要用alert,和整体风格不符
4.ie8,firefox还行,没理由不支持chrome,ie6,7估计会卡死
5.ie8 探测为 ie7 ,chrome 探测为 desktop 了。。。。

总体很不错
0 请登录后投票
   发表时间:2009-06-14  
太强大了。。而且非常漂亮。
0 请登录后投票
   发表时间:2009-07-24  
这个还真是很强大
0 请登录后投票
   发表时间:2009-07-24  
IE下的滤镜用起来估计得卡死
0 请登录后投票
   发表时间:2009-08-04  
IE的滤镜不可大量使用呀
0 请登录后投票
   发表时间:2009-08-17  
技术不懂,但用起来还不错!
0 请登录后投票
   发表时间:2009-08-20  
这个真的不知道,受教了,我是在地震日才第一次知道世界上居然有ie滤镜这玩意
0 请登录后投票
论坛首页 入门技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics