html div全屏遮罩层,javascript div 遮罩层封锁整个页面

具体解决方案如下:

一、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);

}

}

六、DisablePage和DisablePageHaveValidator这两个方法可以在按钮的onclick事件或其它时机调用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值