另一javascript写的类似ModalPopup的效果

这几天路由坏了不能上网,今天看见了杨丹的一片随笔,和偶一样因为ModalPopupExtender 不能激发服务器端事件而郁闷半天。我也用Javascript写了个类似ModalPopup的效果,相比之下代码多了点,但是加了个小功能(从ModalPopup的JS里面提取的,嘿嘿!)。

改变窗体、滚动窗体,漂浮窗口,也随之变化,点击旁边遮掩层(半透明的)可以 关闭浮动窗口。

效果如下:


调整大小:


滚动窗体:


帖代码。。。
CSS:

ContractedBlock.gif ExpandedBlockStart.gif 遮掩层
ExpandedBlockStart.gifContractedBlock.gif#BOX_overlay {dot.gif}{
InBlock.gif     position
: absolute;
InBlock.gif     z-index
:100;
InBlock.gif     top
: 0px;
InBlock.gif     left
: 0px;
InBlock.gif     background-color
:#000;
InBlock.gif     filter
:alpha(opacity=60);
InBlock.gif     -moz-opacity
: 0.6;
InBlock.gif     opacity
: 0.6;
ExpandedBlockEnd.gif
}

Javascript:

 1 None.gif // BOX
 2 ExpandedBlockStart.gifContractedBlock.gif      function  BOX_show(e) dot.gif //显示
 3ExpandedSubBlockStart.gifContractedSubBlock.gif        if($get(e)==null)dot.gif{return;}
 4InBlock.gif        BOX_layout(e);
 5ExpandedSubBlockStart.gifContractedSubBlock.gif        window.onresize = function()dot.gif{BOX_layout(e);} //改变窗体重新调整位置
 6ExpandedSubBlockStart.gifContractedSubBlock.gif        window.onscroll = function()dot.gif{BOX_layout(e);} //滚动窗体重新调整位置
 7ExpandedBlockEnd.gif    }

 8 ExpandedBlockStart.gifContractedBlock.gif     function  BOX_remove(e) dot.gif //移除
 9InBlock.gif        window.onscroll = null;
10InBlock.gif        window.onresize = null;
11InBlock.gif        $get('BOX_overlay').style.display="none";
12InBlock.gif        $get(e).style.display="none";
13ExpandedBlockEnd.gif    }

14 ExpandedBlockStart.gifContractedBlock.gif     function  BOX_layout(e) dot.gif //调整位置
15InBlock.gif        var a = $get(e);
16ExpandedSubBlockStart.gifContractedSubBlock.gif        if ($get('BOX_overlay')==null)dot.gif//判断是否新建遮掩层
17InBlock.gif            var overlay = document.createElement("div");
18InBlock.gif            overlay.setAttribute('id','BOX_overlay');
19ExpandedSubBlockStart.gifContractedSubBlock.gif            overlay.onclick=function()dot.gif{BOX_remove(e);};
20InBlock.gif            a.parentNode.appendChild(overlay);
21ExpandedSubBlockEnd.gif        }

22InBlock.gif        //取客户端左上坐标,宽,高
23InBlock.gif        var scrollLeft = (document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft);
24InBlock.gif        var scrollTop = (document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop);
25InBlock.gif        var clientWidth;
26ExpandedSubBlockStart.gifContractedSubBlock.gif        if (window.innerWidth) dot.gif{
27InBlock.gif            clientWidth = ((Sys.Browser.agent === Sys.Browser.Safari) ? window.innerWidth : Math.min(window.innerWidth, document.documentElement.clientWidth));
28ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 else dot.gif{
29InBlock.gif            clientWidth = document.documentElement.clientWidth;
30ExpandedSubBlockEnd.gif        }

31InBlock.gif        var clientHeight;
32ExpandedSubBlockStart.gifContractedSubBlock.gif        if (window.innerHeight) dot.gif{
33InBlock.gif            clientHeight = ((Sys.Browser.agent === Sys.Browser.Safari) ? window.innerHeight : Math.min(window.innerHeight, document.documentElement.clientHeight));
34ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 else dot.gif{
35InBlock.gif            clientHeight = document.documentElement.clientHeight;
36ExpandedSubBlockEnd.gif        }

37InBlock.gif        var bo = $get('BOX_overlay');
38InBlock.gif        bo.style.left = scrollLeft+'px';
39InBlock.gif        bo.style.top = scrollTop+'px';
40InBlock.gif        bo.style.width = clientWidth+'px';
41InBlock.gif        bo.style.height = clientHeight+'px';
42InBlock.gif        bo.style.display="";
43InBlock.gif        //Popup窗口定位
44InBlock.gif        a.style.position = 'absolute';
45InBlock.gif        a.style.zIndex=101;
46InBlock.gif        a.style.display="";
47InBlock.gif        a.style.left = scrollLeft+((clientWidth-a.offsetWidth)/2)+'px';
48InBlock.gif        a.style.top = scrollTop+((clientHeight-a.offsetHeight)/2)+'px';
49ExpandedBlockEnd.gif    }

第一次发代码有点乱,请见谅。
最后附上 源码
posted on 2006-11-24 15:13 野原新之猪 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/xiaoxinzhu/archive/2006/11/24/571027.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值