css 背景透明 元素(标签)背景透明的css设计

  发布时间:2013-01-09 09:19:18   作者:佚名   我要评论
今天要设计一个定位在图片上的标签,标签的背景要有一定的透明度,使用到了opacity的属性,过去没太注意这个属性的兼容性问题,结果很是郁闷
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

今天要设计一个定位在图片上的标签,标签的背景要有一定的透明度,使用到了opacity的属性,过去没太注意这个属性的兼容性问题,结果采坑了。。。
1.完成后的效果
完成前后的效果应该是这样的: 
背景透明前                                                          背景透明后 
  
tag部分的html应该是这样的

复制代码
代码如下:

<div class="tag">
<span class="tag-bg"></span>
<span class="tag-font">拉萨</span>
</div>

tag部分的css应该是这样的

复制代码
代码如下:

.tag-bg,.tag-font{position:absolute;left:0;bottom:7px;width:50px;height:23px;line-height:23px;font-size: 16px;font-family: "微软雅黑";color:#fff;padding:0 7px;}
.tag-bg{background: #5cbfed;opacity:.7;filter:alpha(opacity=70);-moz-opacity:.7;}

这里提醒下,如果只想背景透明文字不透明,那么一定要设计并列的两个span来分别定义样式。
从上面的代码中可以看出,tag-bg设置的opacity比较复杂,做了多种兼容性处理。
2.透明度的兼容性处理

复制代码
代码如下:

{
opacity:.7; /* 支持CSS3的浏览器(FF 1.5也支持) 透明度70%*/
filter:alpha(opacity=70);/* IE 透明度70%*/
-moz-opacity:.7; /* Moz + FF 透明度70%*/
}

上面的注释已经解释的很清楚了,如果你想做更深入的了解,那么你可以去网络搜寻更多相关的资料。
3.我的实验
上面是理论上的解释,你可能会觉得比较空洞,好吧,我们来做实验,看看不同浏览器下到底是怎样的情况。
我的测试代码: 

复制代码
代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>透明测试</title>
<style>
body{width: 960px;margin: 0 auto;}
div{width: 900px;margin: 0 auto;}
ul li{width: 200px;height: 200px;float: left;margin-right: 5px;background: #00f;color: #fff;list-style: none;padding: 5px;}
.set-opacity{opacity: .5;}
.set-filter{filter:alpha(opacity=50);}
.set-moz{-moz-opacity: .5;}
.set-all{opacity: .5;filter:alpha(opacity=50);-moz-opacity:.5;}
</style>
</head>
<body>
<div>
<ul>
<li class="set-opacity">opacity: .5;</li>
<li class="set-filter">filter:(opacity=50);</li>
<li class="set-opacity-filter">-moz-opacity: .5;</li>
<li class="set-all">opacity: .5;
filter:(opacity=50);
-moz-opacity:.5;</li>
</ul>
</div>
</body>
</html>

下面的各个图中,浅蓝色表明透明度设置成功了,深蓝色表示失败,说明浏览器不识别里面的任何一种设置。
先来看看chrome下的情况: 
 

  可以看出,chrome识别opacity,不识别filter和-moz-opacity。

  IE9下:

  

  ie9比较给力,除了识别filter,也能识别opacity,只是不识别特殊的-moz-opacity。

  IE6,IE7,IE8下:  

  

  ie6、7、8下均只能识别filter。

  FF(16)下:  

  

我的ff16下可以支持opacity,但是不识别filter和-moz-opacity。
如果你有兴趣,还可以将以上代码在更多的浏览器上测试。
从上面的几种情况中已经可以发现了,后一种设置透明度的方式已经可以兼容了各种浏览器。所以,我推荐你使用这样的方式来设置透明度。

相关文章

  • 详解XML中的标签与元素的使用

    这篇文章主要介绍了XML中的标签与元素的使用,是XML入门学习中的基础知识,需要的朋友可以参考下
    2016-02-14
  • div标签中的元素margin-top失效的解决方法

    元素上级标签是div,已经设置了width和height等的属性,可是,在对元素使用margin进行调整的时候,无法生效,下面有个不错的解决方法,感兴趣的朋友可以参考下
    2014-02-17
  • HTML5在a标签内放置块级元素示例代码

    你没看错:用一个A标签包裹块级元素,在HTML5以前,a标签属于行内元素,而div,h1,p 等为块级元素,如果强行包裹,可能会被强行截断为多个a标签,感兴趣的朋友可以了解些
    2013-08-23
  • HTML标签及基本元素学习总结

    最近学习了一些html的知识,以防忘记所以整理了一下,以备不时之需。主要由html的基本元素到超链接、图像之类的,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-06-26
  • HTML中的标签和元素的区别详解

    很多人可能都没有把哪个叫标签,哪个叫元素这个概念搞清楚,包括之前的我也是,一直都是混淆着,特意搜索查阅了一些资料,现将我得出的结论写出来,与大家分享下
    2013-04-22
  • 标签 li 是不是块级元素分析

    块级元素:block-level,相信大家都知道吧(or Google it)。以前在写代码的时候,面对
  • 标签总觉得很奇怪。
2011-04-26
  • HTML元素(标签)大全及使用介绍

    HTML元素(标签)大全及使用说明
    2010-07-04
  • HTML 元素 标签教程

    HTML文档是由HTML元素组成的文本文件。 HTML元素是预定义的正在使用的HTML标签。 HTML标签通常成对出现
    2009-07-16
  • 元素绝对定位以后设置了高宽,a标签不能点击的原因及解决方法

    下面小编就为大家带来一篇元素绝对定位以后设置了高宽,a标签不能点击的原因及解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 最新评论

    微信 投稿 脚本任务 在线工具
    ?


    http://www.vxiaotou.com