`
isiqi
  • 浏览: 16829128 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

另一javascript写的类似ModalPopup的效果

阅读更多

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

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

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

效果如下:


调整大小:


滚动窗体:


帖代码。。。
CSS:

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

Javascript:

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

8functionBOX_remove(e){//移除
9window.onscroll=null;
10window.onresize=null;
11$get('BOX_overlay').style.display="none";
12$get(e).style.display="none";
13}

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

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

31varclientHeight;
32if(window.innerHeight){
33clientHeight=((Sys.Browser.agent===Sys.Browser.Safari)?window.innerHeight:Math.min(window.innerHeight,document.documentElement.clientHeight));
34}
else{
35clientHeight=document.documentElement.clientHeight;
36}

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

第一次发代码有点乱,请见谅。
最后附上源码
分享到:
评论

相关推荐

    asp.net2.0 AjaxControl组件(开源)

    7. **ModalPopup**:创建弹出对话框,可以实现非阻塞的弹窗效果,用户可以在弹窗打开的同时继续与背景页面互动。 8. **Calendar**:提供了一个可自定义的日期选择控件,比内置的ASP.NET Calendar控件更灵活。 9. *...

    AjaxControlToolKit.net4

    8. ModalPopup:弹出式对话框,可以实现模态窗口效果。 9. TabContainer:多标签页布局,便于组织内容。 10. UpdateProgress:显示后台处理进度,提高用户反馈感知。 使用AjaxControlToolkit可以显著减少编写...

    AJAX控件的使用(很强大)

    8. ModalPopup:与ModalPopupExtender类似,但直接作为服务器控件使用,提供更多的自定义选项。 9. Control Extenders:这些扩展器控件可以为现有的ASP.NET控件增加新功能,例如:AutoCompleteExtender可以为...

    AjaxControlToolkit

    AjaxControlToolkit是一个专门为Visual Studio 2005设计的库,它包含了一系列增强Web应用程序交互性和用户体验的Ajax(异步JavaScript和XML)控件。这个工具包极大地简化了开发人员在.NET Framework环境下构建富...

    Ajax Control Toolkit 34个服务器端控件的功能

    这些控件使得开发者能够构建高度交互、响应迅速的Web应用程序,而无需深入JavaScript或AJAX技术的底层细节。在这个压缩包中,你将找到34个不同的服务器端控件,每个都有其独特的特性和应用场景。 1. Accordion:这...

    AJAX常用34个控件及介绍

    CollapsiblePanel 控件类似于 Accordion,但它只包含一个可折叠/展开的面板。 - **功能特性**: - 单一面板可折叠/展开。 - 自定义动画效果。 - **使用示例**: ```html CollapsedHeight="0" ...

Global site tag (gtag.js) - Google Analytics