js弹出的遮罩层,如何能遮住全屏?

JavaScript020

js弹出的遮罩层,如何能遮住全屏?,第1张

工具:电脑;浏览器;ultraedit软件;

操作步骤如下:

1、打开UE编辑器,新建一个空白的html文件和css文件;

2、在html文件中输入以下html代码;

3、在css文件中输入以下css代码;

4、编辑完成之后,选择格式为UTF8-无 BOM模式,保存文件;

5、在浏览器中打开此html文件,可以看到最终想要实现的遮住全屏效果。

弹出div显示遮罩层的效果,想必大家都有见到过吧,下面有个示例,大家可以参考下

代码如下:

//--------------------弹出层-------------------

//popDivId:弹出层div的ID

//dragDivId:用于拖动div的ID

//isShowMask:是否显示遮罩层

function

popDivShow(popDivId,

dragDivId,

isShowMask)

{

if

(isShowMask)

{

creatMask(popDivId)

}

var

oWins

=

document.getElementById(popDivId)

var

oWins_title

=

document.getElementById(dragDivId)

var

bDrag

=

false

var

disX

=

disY

=

0

oWins.style.display

=

"block"

oWins_title.onmousedown

=

function(event)

{

var

event

=

event

||

window.event

bDrag

=

true

disX

=

event.clientX

-

oWins.offsetLeft

disY

=

event.clientY

-

oWins.offsetTop

this.setCapture

&&

this.setCapture()

return

false

}

document.onmousemove

=

function(event)

{

if

(!bDrag)

return

var

event

=

event

||

window.event

var

iL

=

event.clientX

-

disX

var

iT

=

event.clientY

-

disY

var

maxL

=

document.documentElement.clientWidth

-

oWins.offsetWidth

var

maxT

=

document.documentElement.clientHeight

-

oWins.offsetHeight

iL

=

iL

<

0

?

0

:

iL

iL

=

iL

>

maxL

?

maxL

:

iL

iT

=

iT

<

0

?

0

:

iT

iT

=

iT

>

maxT

?

maxT

:

iT

oWins.style.marginTop

=

oWins.style.marginLeft

=

0

oWins.style.left

=

iL

+

"px"

oWins.style.top

=

iT

+

"px"

return

false

}

document.onmouseup

=

window.onblur

=

oWins_title.onlosecapture

=

function()

{

bDrag

=

false

oWins_title.releaseCapture

&&

oWins_title.releaseCapture()

}

}

//

隐藏弹出层

function

popDivHidden(popDivId)

{

var

oWins

=

document.getElementById(popDivId)

oWins.style.display

=

"none"

window.parent.document.body.removeChild(window.parent.document.getElementById("maskDiv"))

}

//

获取弹出层的zIndex

function

getZindex(popDivId)

{

var

popDiv

=

document.getElementById(popDivId)

var

popDivZindex

=

popDiv.style.zIndex

return

popDivZindex

}

//

创建遮罩层

function

creatMask(popDivId)

{

//

参数w为弹出页面的宽度,参数h为弹出页面的高度,参数s为弹出页面的路径

var

maskDiv

=

window.parent.document.createElement("div")

maskDiv.id

=

"maskDiv"

maskDiv.style.position

=

"fixed"

maskDiv.style.top

=

"0"

maskDiv.style.left

=

"0"

maskDiv.style.zIndex

=

getZindex(popDivId)

-

1

maskDiv.style.backgroundColor

=

"#333"

maskDiv.style.filter

=

"alpha(opacity=70)"

maskDiv.style.opacity

=

"0.7"

maskDiv.style.width

=

"100%"

maskDiv.style.height

=

(window.parent.document.body.scrollHeight

+

50)

+

"px"

window.parent.document.body.appendChild(maskDiv)

maskDiv.onmousedown

=

function()

{

window.parent.document.body.removeChild(window.parent.document.getElementById("maskDiv"))

}

}

ps:可能图片颜色有点...umm特别可能看不出来

三个内容的宽度为100%,这样屏幕就会均分三部分。然后将遮罩宽度也设为100%均分,为了让其“盖”在内容上面,需要将遮罩的父div设置成absolute,当然其宽度和高度要和内容一样,最后再设置鼠标的事件监听就好了。

如果你按照我上面所说的思路实现,你会发现:

ps: 遮罩的父布局也要同时隐藏,因为对内容用的是mouseenter,对显示出来的遮罩用mouseleave。如果不把遮罩的父布局隐藏,会无法触发内容的mouseenter(被遮罩父布局挡住了)。这种做法好像很奇怪,有更好的可留言。

刚玩前端呢,想试写game/anime/manga的网站,先把Android放下(分手吧!)。