window.showmodaldialog 用法小结

 Ajax现在都用烂 了,其实有时候对界面和兼容性要求不是太高的时候,一些很简单的方法就可以解决大堆Ajax代码才能解决的问题,比如模态窗口。
    在网上找到了别人对模态窗口的一些总结,特此收藏。

1.打开窗口:
var handle = window.showModalDialog(url, objects, feathers);
其中:objects可以为参数(包括数 组),也可以是对象。
通常的用法 objects = {window} ,把父窗体的对象共享给子窗体。

示例:

//打开模式对话框
function doSelectUser(txtId)
{

      strFeatures="dialogWidth=500px;dialogHeight=360px;center=yes;middle=yes ;help=no;status=no;scroll=no";
      var url,strReturn;
 
      url="selUser.aspx";
       
      strReturn=window.showModalDialog(url,'',strFeatures);  

}

2.关闭子窗口:
window.close();

3.从子窗体传参数给父窗体:
window.returnVal = string;

3.清除缓存,防止模式窗口页面不更新的情况:
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">

4.防止打开新窗口(如提交表单):
<base target="_self">

5.在模式窗口使用F5刷新页面:
<base target="_self">
<body onkeydown="if (event.keyCode==116){reload.click()}">
<a id="reload" href="<%=Request.Url%>" style="display:none"></a>

6.防止模式窗口打开的页面出现cookie丢失的情况:
模式窗口打开新窗口时,仅可以使用 showModalDialog(url,window,feathers); 方法,且 objects 为 window 。

7.在 弹出窗口中获得或设置主窗口的任何值:
打开弹出窗口时用:showModalDialog(url, window, feathers)
在 弹出窗口中使用 window.dialogArguments 对象(即主窗口传递过来的 window 对象集),即可以获得或者设置主窗口的值。




基本介绍:
showModalDialog () (IE 4+ 支持)
showModelessDialog() (IE 5+ 支持)
window.showModalDialog ()方法用来创建一个显示HTML内 容的模态对话框。
window.showModelessDialog()方法用来创建一个显示HTML内容的非模态对话框。

使用方法:

vReturnValue = window.showModalDialog (sURL [, vArguments] [,sFeatures])
vReturnValue = window.showModelessDialog(sURL [, vArguments] [,sFeatures])

参数说明:

sURL--
必选参数,类型:字符串。用来指定对话框要显示的文档的URL。
vArguments--
可选参数,类型:变体。用来向对话框传递参数。传递的参数类型不限,包括数组等。对话框通过window.dialogArguments来取得 传递进来的参数。
sFeatures--
可选参数,类型:字符串。用来描述对话框的外观等信息,可以使用以下的一个或几个,用分号“;”隔开。
1.dialogHeight :对话框高度,不小于100px,IE4中dialogHeight 和 dialogWidth 默认的单位是em,而IE5中是px,为方便其见,在定义modal方式的对话框时,用px做单位。
2.dialogWidth: 对话框宽度。
3.dialogLeft: 离屏幕左的距离。
4.dialogTop: 离屏幕上的距离。
5.center: {yes | no | 1 | 0 }:窗口是否居中,默认yes,但仍可以指定高度和宽度。
6.help: {yes | no | 1 | 0 }:是否显示帮助按钮,默认yes。
7.resizable: {yes | no | 1 | 0 } [IE5+]:是否可被改变大小。默认no。
8.status: {yes | no | 1 | 0 } [IE5+]:是否显示状态栏。默认为yes[ Modeless]或no[Modal]。
9.scroll:{ yes | no | 1 | 0 | on | off }:指明对话框是否显示滚动条。默认为yes。
下面几个属性是用在HTA中的,在一般的网页中一般不使用。
10.dialogHide:{ yes | no | 1 | 0 | on | off }:在打印或者打印预览时对话框是否隐藏。默认为no。
11.edge:{ sunken | raised }:指明对话框的边框样式。默认为raised。
12.unadorned:{ yes | no | 1 | 0 | on | off }:默认为no。


参数传递方法:

父窗口向子窗口传递参数采用ShowModalDialog 的第2个参数即可,父窗 口要获取子窗口传回的参数则可通过ShowModalDialog 函数的返回值获取。
子窗口获取父窗口参数的方法为采用子窗口window对象dialogArguments属性获取,例如:
var a=window.dialogArguments;
子窗口向父窗口返回参数采用window.returnValue属性,如:
window.returnValue=1;
window.close();

 

 

 

一个示例                        <INPUT TYPE="BUTTON" NAME="Button" VALUE="单击这里看看效果" onclick="showModalDialog('http://192.168.1.23',window,'dialogWidth=600px;dialogHeight=500px;center=yes;middle=yes;help=no;status=no;scroll=no;resizable=no;')">

 

 

-------------------------------------------------------------------------------------------------------------

 

自己写的,有不正确的地方,请留言。

参数传递的示例

父窗口

 

<script type="text/javascript">
        var btn = document.getElementById("btn1");
        btn.onclick = function () {
            var Url = 'http://192.168.1.23:9000/maillogin.aspx';
            var strFeatures = 'dialogWidth=600px;dialogHeight=500px;center=yes;middle=yes;help=no;status=no;scroll=no;resizable=no;';
            var objects = [window, 'sdfsdfsdfsd'];//传递的参数列表
           var k=   showModalDialog(Url, objects, strFeatures);//获取返回值
          
            alert(k);
        }

 

 

mailloign.aspx获得父窗口的参数

<script type="text/javascript">
    var a = window.dialogArguments;
    alert(a);
</script>

 

子窗口 中,不执行服务器按钮事件??????

但是可以 执行Page_Load() 里的事件

也可以执行客户端的事件


<input id="Button2" type="button" value="button" onclick="alert('23您好');window.returnValue=1;
window.close();" />

 


window.returnValue设置返回值

你可能感兴趣的:(window.showmodaldialog 用法小结)