【原】CSS实现背景透明,文字不透明,兼容所有浏览器

摘要:
11.11这是公司成立的日子。我16岁。我三岁半。感谢公司给我这样一个学习和成长的平台。在此,我祝愿公司越来越好。光棍节成为主题。每年11月11日是光棍节,光棍节诞生于校园。最初,这只是一个流行于年轻人的娱乐节日,庆祝我为单身感到骄傲。现在是各大商家以裸体为由打折促销的时候了,这已经成为了所谓的“购物节”。双11没关系,但我们必须在晚些时候举行双12,所以我们不得不吐槽它。所以,我们熬夜加班做11.11的活动,并在PC端见面

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

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

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

重点内容入口:

测试浏览器:

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

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

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

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第1张

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

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第2张

实现透明的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及以上版本和标准浏览器都支持

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第3张

使用说明:设置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后整个模块都透明了,展现如下:

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第4张

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

css3的rgba

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

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第3张

使用说明:设置颜色的不透明度,一般用于调整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,标准浏览器中,背景透明,文字不透明,展现如下:

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第6张

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

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第7张

那么使用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,其兼容性如下图所示:

【原】CSS实现背景透明,文字不透明,兼容所有浏览器第8张

针对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 

免责声明:内容来源于网络,仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇阿里最新热修复Sophix与QQ超级补丁和Tinker的实现与总结Oracle DBLINK 简单使用下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

出现“基础链接已关闭,无法链接到远程服务器"错误的解决办法

一些用户在安装一些软件或是系统做某些修改后,采集器就没无登录或是无法获取到网页。登录或是使用httppostget工具会出现 ”基础链接已关闭,无法链接到远程服务器“的提示。经分析,是系统Socket组件错误,重启socket组件,一切正常。 以下内容来自并经验证有效:http://blog.csdn.net/kongdeqian1988/article/...

微软脱机实验五十微软应用程序虚拟化之五APPV 5.1脱机使用应用程序

文章结束给大家来个程序员笑话:[M] 实验五十微软应用程序虚拟化之五APP-V 5.1脱机应用应用程序 APP-V 5.1中客户端要应用程序可以通过在线方式应用程序,也可以离线应用程序,但是离线应用时必须先把虚拟程序下载到当地,此时须要手动联机更新程序和下载最新程序。从这点可以看出APP—V是运行在客户端的虚拟化程序调用的是当地资源,而Remoteap...

通过CSS3伪类,美化Radio按钮样式

CSS3样式: /* RADIO */.button-holder {100%;}.regular-radio {display: none;}.regular-radio + label {-webkit-appearance: none;background-color: #fafafa;border: 1px solid #cacece;box-sh...

AndroidStudio技巧之copy工程

为了减少重复写代码,我们经常需要将一个已经写好的android工程拷贝成为一个新的工程,但是这个工程在运行时又会出现这样那样的问题: 比如: 原来的app文件会被覆盖掉 sd卡中旧的app文件目录被覆盖 解决: 1:修改包名,定义成你觉得与功能相对应的 2:在工程中找到GradleScripts文件夹下的build.gradle(Module:a...

Emoji表情符号兼容方案

Emoji表情符号兼容方案 一 什么是Emoji emoji就是表情符号;词义来自日语(えもじ,e-moji,moji在日语中的含义是字符)表情符号现已普遍应用于手机短信和网络聊天软件。emoji表情符号,在外国的手机短信里面已经是很流行使用的一种表情。手机上如何使用emoji:1.iphone、ipad系统:安装emoji free,再设置-通用-键盘...

H5开发:横屏适配

平常我们做过的需求里,主要是以竖屏式为主,而横屏式较少。对于竖屏式场景来说,大家的经验会比较丰富,因此,此次主要式探讨下横屏式场景下的一些需要注意的点,特别是怎样去做横屏适配。 对于 H5 横屏页面来说,要实现横屏的话,主要是解决两点:1.无论用户手持方向如何,都需要保证屏幕横向显示。2.由于屏幕分辨率的多样化,因此就算是横屏下也是需要进行横屏适配,保证页...