来自小新的博客http://www.cnblogs.com/xiaoxinzhu/archive/2006/11/24/571027.html

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

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

效果如下:
另一javascript写的类似ModalPopup的效果

调整大小:
另一javascript写的类似ModalPopup的效果

滚动窗体:
另一javascript写的类似ModalPopup的效果

帖代码。。。
CSS:

另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果遮掩层
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果#BOX_overlay{另一javascript写的类似ModalPopup的效果}{
另一javascript写的类似ModalPopup的效果position
:absolute;
另一javascript写的类似ModalPopup的效果z-index
:100;
另一javascript写的类似ModalPopup的效果top
:0px;
另一javascript写的类似ModalPopup的效果left
:0px;
另一javascript写的类似ModalPopup的效果background-color
:#000;
另一javascript写的类似ModalPopup的效果filter
:alpha(opacity=60);
另一javascript写的类似ModalPopup的效果-moz-opacity
:0.6;
另一javascript写的类似ModalPopup的效果opacity
:0.6;
另一javascript写的类似ModalPopup的效果
}

Javascript:

1另一javascript写的类似ModalPopup的效果//BOX
2另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果functionBOX_show(e)另一javascript写的类似ModalPopup的效果{//显示
3另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果if($get(e)==null)另一javascript写的类似ModalPopup的效果{return;}
4另一javascript写的类似ModalPopup的效果BOX_layout(e);
5另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果window.onresize=function()另一javascript写的类似ModalPopup的效果{BOX_layout(e);}//改变窗体重新调整位置
6另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果window.onscroll=function()另一javascript写的类似ModalPopup的效果{BOX_layout(e);}//滚动窗体重新调整位置
7另一javascript写的类似ModalPopup的效果}

8另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果functionBOX_remove(e)另一javascript写的类似ModalPopup的效果{//移除
9另一javascript写的类似ModalPopup的效果window.onscroll=null;
10另一javascript写的类似ModalPopup的效果window.onresize=null;
11另一javascript写的类似ModalPopup的效果$get('BOX_overlay').style.display="none";
12另一javascript写的类似ModalPopup的效果$get(e).style.display="none";
13另一javascript写的类似ModalPopup的效果}

14另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果functionBOX_layout(e)另一javascript写的类似ModalPopup的效果{//调整位置
15另一javascript写的类似ModalPopup的效果vara=$get(e);
16另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果if($get('BOX_overlay')==null)另一javascript写的类似ModalPopup的效果{//判断是否新建遮掩层
17另一javascript写的类似ModalPopup的效果varoverlay=document.createElement("div");
18另一javascript写的类似ModalPopup的效果overlay.setAttribute('id','BOX_overlay');
19另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果overlay.onclick=function()另一javascript写的类似ModalPopup的效果{BOX_remove(e);};
20另一javascript写的类似ModalPopup的效果a.parentNode.appendChild(overlay);
21另一javascript写的类似ModalPopup的效果}

22另一javascript写的类似ModalPopup的效果//取客户端左上坐标,宽,高
23另一javascript写的类似ModalPopup的效果varscrollLeft=(document.documentElement.scrollLeft?document.documentElement.scrollLeft:document.body.scrollLeft);
24另一javascript写的类似ModalPopup的效果varscrollTop=(document.documentElement.scrollTop?document.documentElement.scrollTop:document.body.scrollTop);
25另一javascript写的类似ModalPopup的效果varclientWidth;
26另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果if(window.innerWidth)另一javascript写的类似ModalPopup的效果{
27另一javascript写的类似ModalPopup的效果clientWidth=((Sys.Browser.agent===Sys.Browser.Safari)?window.innerWidth:Math.min(window.innerWidth,document.documentElement.clientWidth));
28另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果}
else另一javascript写的类似ModalPopup的效果{
29另一javascript写的类似ModalPopup的效果clientWidth=document.documentElement.clientWidth;
30另一javascript写的类似ModalPopup的效果}

31另一javascript写的类似ModalPopup的效果varclientHeight;
32另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果if(window.innerHeight)另一javascript写的类似ModalPopup的效果{
33另一javascript写的类似ModalPopup的效果clientHeight=((Sys.Browser.agent===Sys.Browser.Safari)?window.innerHeight:Math.min(window.innerHeight,document.documentElement.clientHeight));
34另一javascript写的类似ModalPopup的效果另一javascript写的类似ModalPopup的效果}
else另一javascript写的类似ModalPopup的效果{
35另一javascript写的类似ModalPopup的效果clientHeight=document.documentElement.clientHeight;
36另一javascript写的类似ModalPopup的效果}

37另一javascript写的类似ModalPopup的效果varbo=$get('BOX_overlay');
38另一javascript写的类似ModalPopup的效果bo.style.left=scrollLeft+'px';
39另一javascript写的类似ModalPopup的效果bo.style.top=scrollTop+'px';
40另一javascript写的类似ModalPopup的效果bo.style.width=clientWidth+'px';
41另一javascript写的类似ModalPopup的效果bo.style.height=clientHeight+'px';
42另一javascript写的类似ModalPopup的效果bo.style.display="";
43另一javascript写的类似ModalPopup的效果//Popup窗口定位
44另一javascript写的类似ModalPopup的效果a.style.position='absolute';
45另一javascript写的类似ModalPopup的效果a.style.zIndex=101;
46另一javascript写的类似ModalPopup的效果a.style.display="";
47另一javascript写的类似ModalPopup的效果a.style.left=scrollLeft+((clientWidth-a.offsetWidth)/2)+'px';
48另一javascript写的类似ModalPopup的效果a.style.top=scrollTop+((clientHeight-a.offsetHeight)/2)+'px';
49另一javascript写的类似ModalPopup的效果}

第一次发代码有点乱,请见谅。
最后附上源码

相关文章:

  • 2021-07-04
  • 2021-06-14
  • 2021-10-22
  • 2022-12-23
  • 2021-06-21
  • 2022-12-23
  • 2022-12-23
  • 2021-11-14
猜你喜欢
  • 2021-05-25
  • 2022-01-06
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-22
  • 2021-08-01
相关资源
相似解决方案