Home >Web Front-end >HTML Tutorial >[Original] CSS realizes transparent background and opaque text, compatible with all browsers_html/css_WEB-ITnose

[Original] CSS realizes transparent background and opaque text, compatible with all browsers_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 11:54:151192browse

11.11也是公司成立的日子,16岁啦,我呢3岁半,感谢公司给了这样一个平台,让我得以学习和成长,这里祝愿公司发展越来越好~

进入主题,每年11月11号是光棍节,产生于校园,本来只是一流传于年轻人的娱乐性节日,以庆祝自己仍是单身一族为骄傲,而如今是各大商家以脱光为由打折促销的时期,成为了所谓的”购物节“,双11也算了,后面还要搞双12,不得不吐槽下。

于是呢,熬夜加班做了11.11的活动,在PC端遇到了透明背景和透明图片的问题,其实以前也遇到过,只是没有总结起来,就忘记了,这次又撞墙了,必须记录下来,一来给自己做个小总结,提个醒,最近变懒了,再不努力就要倒挂了;二来是因为在网络上并没有完整的解决方案,希望可以帮助到遇到此类问题的朋友,今天主要讲解背景透明的解决方案,共勉~

重点内容入口:

  • IE6和部分IE7内核的浏览器会读懂rgba
  • IE专属滤镜 filter:Alpha的兼容处理
  • 背景透明,文字不透明全兼容方案
  • 测试浏览器:

    VirtIE6、虚拟机下XP的IE6、纯正IE8、纯正IE8下QQ浏览器、WIN7下的IE 9.0.32 、WIN8下的IE 10.0.21、chrome 38.0 、QQ浏览器8.0-IE10.0.5、safari 5.1.7、opera 25.0

    如何实现背景透明,文字不透明,兼容所有浏览器?

    我们平时所说的调整透明度,其实在样式中是调整不透明度,如下图所示例:

    打开ps,在图层面板上,可以看到设置图层整理不透明度的菜单,从 0% (完全透明)到 100%(完全不透明)。

    实现透明的css方法通常有以下3种方式,以下是不透明度都为80%的写法

  • css3的opacity:x,x 的取值从 0 到 1,如opacity: 0.8
  • css3的rgba(red, green, blue, alpha),alpha的取值从 0 到 1,如rgba(255,255,255,0.8)
  • IE专属滤镜 filter:Alpha(opacity=x),x 的取值从 0 到 100,如filter:Alpha(opacity=80)
  • css3的opacity

    兼容性:IE6、7、8不支持,IE9及以上版本和标准浏览器都支持

    使用说明:设置opacity元素的所有后代元素会随着一起具有透明性,一般用于调整图片或者模块的整体不透明度

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>opacity</title><style>*{    padding: 0;    margin: 0;}body{    padding: 50px;    background: url(img/bg.png) 0 0 repeat;}.demo{  padding: 25px;  background-color:#000000;  opacity: 0.2;}.demo p{    color: #FFFFFF;}</style></head><body>    <div class="demo">    <p>背景透明,文字也透明</p></div></html>

    使用opacity后整个模块都透明了,展现如下:

    那么使用opacity实现《背景透明,文字不透明》是不可取的。

    css3的rgba

    兼容性:IE6、7、8不支持,IE9及以上版本和标准浏览器都支持

    使用说明:设置颜色的不透明度,一般用于调整background-color、color、box-shadow等的不透明度。

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>css3的rgba</title><style>*{    padding: 0;    margin: 0;}body{    padding: 50px;    background: url(img/bg.png) 0 0 repeat;}.demo{  padding: 25px;  background-color:#000000;/* IE6和部分IE7内核的浏览器(如QQ浏览器)下颜色被覆盖 */  background-color:rgba(0,0,0,0.2); /* IE6和部分IE7内核的浏览器(如QQ浏览器)会读懂,但解析为透明 */}.demo p{    color: #FFFFFF;}</style></head><body>    <div class="demo">    <p>背景透明,文字也透明</p></div></html>

    在background-color中使用rgba,标准浏览器中,背景透明,文字不透明,展现如下:

    很奇葩的是,IE6和部分IE7内核的浏览器(如QQ浏览器)会读懂rgba,解析后颜色为透明,其实应该是null

    那么使用opacity实现背景透明,文字不透明是可取的。

    IE专属滤镜 filter:Alpha(opacity=x)

    使用说明:IE浏览器专属,问题多多,本文以设置背景透明为例子,如下:

    1. 仅支持IE6、7、8、9,在IE10版本被废除
    2. 在IE6、7中,需要激活IE的haslayout属性(如:*zoom:1或者*overflow:hidden),让它读懂filter:Alpha
    3. 在IE6、7、8中,设置了filter:Alpha的元素,父元素设置position:static(默认属性),其子元素为相对定位,可让子元素不透明

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>opacity</title><style>*{    padding: 0;    margin: 0;}body{    padding: 50px;    background: url(img/bg.png) 0 0 repeat;}.demo{  padding: 25px;  background: #000000;  filter:Alpha(opacity=50);/* 只支持IE6、7、8、9 */  position:static; /* IE6、7、8只能设置position:static(默认属性) ,否则会导致子元素继承Alpha值 */  *zoom:1; /* 激活IE6、7的haslayout属性,让它读懂Alpha */}.demo p{    color: #FFFFFF;    position: relative;/* 设置子元素为相对定位,可让子元素不继承Alpha值,保证字体颜色不透明 */}      </style></head><body>    <div class="demo">    <p>背景透明,文字不透明</p></div>

    全兼容的方案

    上以上3点分析可知,设置透明背景文字不透明,可采用的属性有rgba和IE的专属滤镜filter:Alpha,其兼容性如下图所示:

    针对IE6、7、8浏览器,我们可以采用fiter:Alpha,针对标准浏览器我们采用rgba,那么问题来了,IE9浏览器2个属性都支持,一起使用会重复降低不透明度...

    那么,如何只对IE6、7、8使用fiter:Alpha如何实现呢?2年前写过《CSS hack整理》一文,最新我也做了点更新,里面有IE的相关hack,找到只支持IE 6、7、8的方案,如下:

    /* 只支持IE6、7、8 */@media \0screen\,screen\9 {...}

    ok,所有问题都解决了,全部代码如下:

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>背景透明,文字不透明</title><style>*{    padding: 0;    margin: 0;}body{  padding: 50px;  background: url(img/bg.png) 0 0 repeat;}.demo{  padding: 25px;  background-color: rgba(0,0,0,0.5);/* IE9、标准浏览器、IE6和部分IE7内核的浏览器(如QQ浏览器)会读懂 */}.demo p{  color: #FFFFFF;}@media \0screen\,screen\9 {/* 只支持IE6、7、8 */  .demo{    background-color:#000000;    filter:Alpha(opacity=50);    position:static; /* IE6、7、8只能设置position:static(默认属性) ,否则会导致子元素继承Alpha值 */    *zoom:1; /* 激活IE6、7的haslayout属性,让它读懂Alpha */  }  .demo p{    position: relative;/* 设置子元素为相对定位,可让子元素不继承Alpha值 */  }  }</style></head><body>    <div class="demo">    <p>背景透明,文字不透明</p></div></html>

    下载demo

    Many students may find it very complicated. Why not just use two DIVs in the same position, one opaque DIV and one text DIV. It is a very simple way to solve the problem. This is also a good method, but it needs to be written absolutely Positioning or negative margin, and a DIV with empty content appears, and this method can also be complicated in some scenarios. In the following example, after the mouse passes over the trademark to display a transparent prompt copy, you need to control 2 DIVs~

    Some ideas, if you have any questions, you are welcome to leave a message~

    Statement:
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn