求CSS加遮罩的操作方法

html-css016

求CSS加遮罩的操作方法,第1张

具体解决方案如下:

一、IE和FF下document.body对象的clientHeight,offsetHeight,scrollHeight属性的差别。

clientHeight

在IE和FF下,该属性没什么差别,都是指浏览器的可视区域,即除去浏览器的那些工具栏状态栏剩下的页面展示空间的高度。

offsetHeight

在IE下,offsetHeight也是浏览器可视区域的高(包括边线)

在FF下,offsetHeight是页面具体内容的高度

scrollHeight

在IE下,scrollHeight 是页面具体内容的高度,可以小于clientHeight

在FF下,scrollHeight 是网页内容高度,不过最小值是clientHeight

二、下面是跨浏览器取得当前页面的高度的解决方法。

复制代码 代码如下:

function getPageSize()

{

var body = document.documentElement;

var bodyOffsetWidth = 0

var bodyOffsetHeight = 0

var bodyScrollWidth = 0

var bodyScrollHeight = 0

var pageDimensions = [0,0]

pageDimensions[0]=body.clientHeight

pageDimensions[1]=body.clientWidth

bodyOffsetWidth=body.offsetWidth

bodyOffsetHeight=body.offsetHeight

bodyScrollWidth=body.scrollWidth

bodyScrollHeight=body.scrollHeight

if(bodyOffsetHeight >pageDimensions[0])

{

pageDimensions[0]=bodyOffsetHeight

}

if(bodyOffsetWidth >pageDimensions[1])

{

pageDimensions[1]=bodyOffsetWidth

}

if(bodyScrollHeight >pageDimensions[0])

{

pageDimensions[0]=bodyScrollHeight

}

if(bodyScrollWidth >pageDimensions[1])

{

pageDimensions[1]=bodyScrollWidth

}

return pageDimensions

}

三、页面上必须放置一个div,作为遮罩层,下面是这个遮罩层的css样式。

复制代码 代码如下:

.lockDiv

{

position:absolute

left:0

top:0

height:0

width:0

border:2 solid red

display:none

text-align:center

background-color:#DBDBDB

filter:Alpha(opacity=60)

}

四、在客户端使用下面的javascript用遮罩层将整个页面封闭。

复制代码 代码如下:

var sandglassSpan = 1

var timeHdl

function DisablePage()

{

var ctrlSandglass = document.getElementById("divSandglass")

if(sandglassSpan==0)

{

window.clearTimeout(timeHdl)

ctrlSandglass.style.display = "none"

document.body.style.cursor = 'auto'

sandglassSpan = 1

}

else

{

document.body.style.cursor = 'wait'

var pageDimensions = getPageSize()

ctrlSandglass.style.top = 0

ctrlSandglass.style.left = 0

ctrlSandglass.style.height = pageDimensions[0]

ctrlSandglass.style.width = pageDimensions[1]

ctrlSandglass.style.display = "block"

timeHdl = window.setTimeout(DisablePage,200)

}

}

五、如果页面上使用了ASP.net的Validator控件,那么应该使用如下的javascript。

复制代码 代码如下:

var sandglassSpan = 1

var timeHdl

function DisablePageHaveValidator()

{

var ctrlSandglass = document.getElementById("divSandglass")

if(false == Page_IsValid)

{

sandglassSpan = 0

}

if(sandglassSpan==0)

{

window.clearTimeout(timeHdl)

ctrlSandglass.style.display = "none"

document.body.style.cursor = 'auto'

sandglassSpan = 1

}

else

{

document.body.style.cursor = 'wait'

ctrlSandglass.style.display = "block"

var pageDimensions = getPageSize()

ctrlSandglass.style.top = 0

ctrlSandglass.style.left = 0

ctrlSandglass.style.height = pageDimensions[0]

ctrlSandglass.style.width = pageDimensions[1]

timeHdl = window.setTimeout(DisablePageHaveValidator, 200)

}

}

不是很明白你要的是什么效果,既然是导航,本来z-index就会高于内容,不会影响误操作到内容,没必要做遮罩层。鼠标放到哪,哪模糊,用a:hover实现就行了,你如果要遮罩整个界面而不只是导航下面那部分,那做一个遮罩层就行了,做成半透明,控制他的display在none和block之间变换,绑定移入移出事件给导航的各个元素。

1.首先,看一下HTML,一个img图像控件和一个带有样式的div,其中包含文本。这个就是蒙版遮罩层。

2.然后,查看样式定义。先检查图像容器和图像样式,如图所示。其中要注意的是img_container样式里定义了position:relative,这个主要是为了遮罩层做绝对定位做准备的。

3.接着,查看遮罩层的样式定义。该代码如图所示。

背景:rgba(0,0,0,0.7);

可以通过修改以下数字0.7来更改透明度。 1是完全不透明的,0是完全透明的。

4.随后,添加用于鼠标移动的脚本代码以显示遮罩层。该js代码是用jquery编写的,既方便又简单,因此首先介绍jquery脚本库。

5.然后,添加mouseover和mouseout事件,主要是当鼠标移到图像容器时显示遮罩层,并在鼠标移出时隐藏遮罩层。

6.刷新页面,可以看到页面上显示的普通图片。

7.最后,可以看到当鼠标放在图片上时,将显示遮罩层。