1 、半透明效果可以使用 css3 中的 opacity 属性,在低版本的IE浏览器中使用IE的alpha 滤镜。代码:
.opacity{
opacity:0.3filter: alpha(opacity=30)background-color:#000}
2
、要覆盖整个可视区域通常的做法是:
html,body{ height:100%}
.mask{height:100%width:100%}
但是这样做当内容超过一屏时只有IE6下显示的效果是我们所期望的,在其他浏览器中首屏以下的没能被遮盖住,为了兼容其他浏览器我们可以使用position:fixed
来解决这个问题
完整的代码:
<div class="mask opacity"></div>
html,body{ height:100%margin:0padding:0}
.mask{height:100%
width:100%position:fixed_position:absolutetop:0z-index:1000}
.opacity{ opacity:0.3filter: alpha(opacity=30)background-color:#000
}
给你一个例子:
<!DOCTYPE html><html>
<head>
<meta
charset="gb2312" />
<title>背景半透明覆盖整个可视区域</title>
<style>
html,body{ height:100% margin:0 padding:0
font-size:14px}
p{ line-height:18px}
.mask{height:100% width:100%
position:fixed _position:absolute top:0 z-index:1000 }
.opacity{
opacity:0.3 filter: alpha(opacity=30) background-color:#000 }
.content{height:600px width:800px overflow:auto border:2px solid #ccc
background-color:#fff position:absolute top:50% left:50% margin:-300px auto
auto -400px z-index:1001 word-wrap: break-word padding:3px}
.ph{
height:1000px}
</style>
</head>
<body>
<p
class="ph">place holder height:1000px</p>
<div class="mask
opacity"></div>
<div class="content">
<h1>背景半透明覆盖整个可视区域</h1>
<p>
这个效果效果在工作中经常会遇到,这篇文章主要介绍了当内容超过一屏时如何做到多浏览器的兼容性。 下面我们通过一个简单的例子看看如何实现,高手请绕道。
</p>
<p>html代码很简单 < d i v class="mask opacity">< / d i
v > </p>
<p> 1 、半透明效果可以使用 css3 中的 opacity
属性,在低版本的IE浏览器中使用IE的alpha 滤镜。代码:
<code>.opacity{ opacity:0.3
filter: alpha(opacity=30) background-color:#000 }</code> </p>
<p> 2 、要覆盖整个可视区域通常的做法是: <br/>
<code> html,body{
height:100%} </code> <br/>
<code>.mask{height:100%width:100%}</code> <br/>
但是这样做当内容超过一屏时只有IE6下显示的效果是我们所期望的,在其他浏览器中首屏以下的没能被遮盖住,为了兼容其他浏览器我们可以使用<code>position:fixed
</code>来解决这个问题 </p>
<p>
<strong>完整的代码</strong>:
<pre>
html,body{ height:100%
margin:0 padding:0}
.mask{height:100% width:100% position:fixed
_position:absolute top:0 z-index:1000 }
.opacity{ opacity:0.3 filter:
alpha(opacity=30) background-color:#000 }
</pre>
</p>
<p> <strong>参考资料:</strong>
<a href="http://zhidao.baidu.com">背景半透明最佳实践</a>
<a href="http://baidu.com">垂直居中的几种实现方法</a>
<a href="http://tieba.baidu.com">DIV高度100%</a>
</p>
</div>
</body>
</html>
首先回忆一下弹窗的实现,一般我们分为两层,弹出窗口层(popus)和遮罩层(mask),通常情况下我习惯就这两元素全部设成fixed定位,具体和absolute区别一试便知。对于mask层自不用多少,我们如下给他设置属性,让他铺满整个屏幕。.mask{position:fixedtop:0pxbottom:0pxleft:0pxright:0pxbackground-color:#000opacity:0.6filter:alpha(opacity=60)}
popus层则要稍微麻烦点儿,这里我们有两种实现方法
1.已知大小的弹窗,如下,主要通过top,left与负的margin来实现。
.popus{width:300pxheight:200pxposition:fixedleft:50%top:50%margin-left:-150pxmargin-top:-100pxbackground-color:#000}
2.未知弹窗大小,则通过js获取弹窗层的width与height,然后在进行如上设置,在此不多述。
3.在支持css3的情况下,我们不需要知道弹窗的宽高,便可进行如下设置
.popus{position:fixedleft:50%top:50%transform:translate(-50%,-50%)}
主要通过translate属性来设置,偏移的值百分比是相对于本身的宽高,因此从原理上来说跟第一种写法有异曲同工之妙,不过使用却更方便。
言归正传,下面我们回归到正题,即让元素实现ps中高斯模糊的效果。
这里引出一个css属性:filter,注意这里的filter并不是ie中的filter,filter有很多值,感兴趣的可以点击这里,作者讲的非常详细。我们今天只讲其中的一个blur,首先看下面的预览图
ps:目前来说该属性只支持webkit浏览器,所以我们直接使用了css3属性,效果也需要在webkit浏览器中查看
是不是很神奇,其中起作用的代码就这一行 -webkit-filter:blur(8px) ,后面的像素值即代表模糊程度,当然在日常项目中,我们还可以加一些动画,使页面更加的生动,本案例完整代码如下:
<div class='bg'>
<img src='bg.jpg' />
</div>
<div class='popus'>
效果是不是要好过纯色加透明呢
<div>
<div class='left btn '>确实不错</div>
<div class='right btn'>也就那样</div>
</div>
</div>
css:
*{padding:0pxmargin:0px}
img{width:100%margin:0px autodisplay:block}
.bg.blur{-webkit-filter:blur(8px)}
.popus{width:400pxcolor:#000position:fixedtop:50%left:50%-webkit-transform:translate(-50%,-50%)font-family:"微软雅黑"padding:20px 0pxfont-weight:boldbackground-color:rgba(255,255,255,0.6)border-radius:18pxtext-align:centerpadding:30px 0pxbox-shadow:0px 0px 10px rgba(0,0,0,0.4)display:none}
.popus div{width:220pxmargin:10px auto}
.popus div.btn{width:80pxpadding:5px 10pxcolor:#000}
.left{float:leftborder:1px solid #000}
.popus div.btn.right{float:rightcolor:#666}
js:
$('.bg').on('click',function(){
console.log(98)
$(this).addClass('blur')
$('.popus').show()
})
$('.btn').on('click',function(){
$('.bg').removeClass('blur')
$('.popus').hide()
})
这样是不是就完了?很明显不是,看控制台
当我们弹出窗口外,肯定要禁止掉我们其他层的点击事件,但是我们发现目前我们虽然将其他层模糊化了,但是并没有禁止掉相应的事件,当然解决办法也很简单,我们可以加一层没有背景颜色的遮罩层,覆盖在页面上,这样我们每次点击作用在遮罩层上,自然不会触发底层的事件了。
-webkit- mask这个属性如何获取?如果熟悉Flash的人的话,就知道有个“遮罩层”的东西,也就是如果根据遮罩层的颜色的深浅来显示位于遮罩层下方的图像,在这里的话,-webkit-mask是采用opacity透明度来实现遮罩的,如果透明度为1则显示,透明度为0则不显示,介于0-1之间则呈现相应的透明度-webkit-mask也是一个复合属性,语法如下:
-webkit-mask:attachment, clip, origin, image, repeat, composite, box-image