showModalDialog和showModelessDialog使用心得
时间:2007-11-16 来源:xiang588
在window.showModalDialog中这样去掉水平滚动条,在弹出网页的CSS表中加上
    html,body
    {
    overflow-x:hidden
    }
  
    一、showModalDialog和showModelessDialog有什么不同?
      showModalDialog:被打开后就会始终保持输入焦点。除非对话框被关闭,否则用户无法切换到主窗口。类似alert的运行效果。
      showModelessDialog:被打开后,用户可以随机切换输入焦点。对主窗口没有任何影响(最多是被挡住一下而以。:P)
  
    二、怎样才让在showModalDialog和showModelessDialog的超连接不弹出新窗口?
      在被打开的网页里加上<base target="_self">就可以了。这句话一般是放在<html>和<body>之间的。
  
    三、怎样才刷新showModalDialog和showModelessDialog里的内容?
      在showModalDialog和showModelessDialog里是不能按F5刷新的,又不能弹出菜单。这个只能依靠javascript了,以下是相关代码:
  
    <body onkeydown="if (event.keyCode==116){reload.click()}">
    <a id="reload" href="filename.htm" style="display:none">reload...</a>
  
将filename.htm替换成网页的名字然后将它放到你打开的网页里,按F5就可以刷新了,注意,这个要配合<base target="_self">使用,不然你按下F5会弹出新窗口的。
    四、如何用javascript关掉showModalDialog(或showModelessDialog)打开的窗口。
      <input type="button" value="关闭" onclick="window.close()">
      也要配合<base target="_self">,不然会打开一个新的IE窗口,然后再关掉的。
  
    五、showModalDialog和showModelessDialog数据传递技巧。
      (作者语:本来想用一问一答形式来写的,但是我想不出这个怎么问,所以只好这样了。)
      这个东西比较麻烦,我改了好几次了不是没办法说明白(语文水平越来越差了),只好用个例子说明了。
      例子:
        现在需要在一个showModalDialog(或showModelessDialog)里读取或设置一个变量var_name
  
          一般的传递方式:
            window.showModalDialog("filename.htm",var_name)
            //传递var_name变量
          在showModalDialog(或showModelessDialog)读取和设置时:
            alert(window.dialogArguments)//读取var_name变量
            window.dialogArguments="oyiboy"//设置var_name变量
        这种方式是可以满足的,但是当你想在操作var_name同时再操作第二个变理var_id时呢?就无法再进行操作了。这就是这种传递方式的局限性。
        
          以下是我建议使用的传递方式:
            window.showModalDialog("filename.htm",window)
            //不管要操作什么变量,只直传递主窗口的window对象
          在showModalDialog(或showModelessDialog)读取和设置时:
            alert(window.dialogArguments.var_name)//读取var_name变量
            window.dialogArguments.var_name="oyiboy"//设置var_name变量
  
            同时我也可以操作var_id变量
            alert(window.dialogArguments.var_id)//读取var_id变量
            window.dialogArguments.var_id="001"//设置var_id变量
  
            同样还可以对主窗口的任何对象进行操作,如form对象里的元素。
            window.dialogArguments.form1.index1.value="这是在设置index1元素的值"
  
    六、多个showModelessDialog的相互操作。
      因为光说很费劲,我就偷点懒,直接用代码来说了,如果不明白的话那就直接来信(oyiboy#163.net(使用时请将#改成@))问我吧。
  
以下代码的主要作用是在一个showModelessDialog里移动别一个showModelessDialog的位置。
      主文件的部份js代码。
      var s1=showModelessDialog('控制.htm',window,"dialogTop:1px;dialogLeft:1px") //打开控制窗口
      var s2=showModelessDialog('about:blank',window,"dialogTop:200px;dialogLeft:300px")  //打开被控制窗口
  
      控制.htm的部份代码。
      
      <input type="button" onclick="window.dialogArguments.s2.dialogTop=countNumber(window.dialogArguments.s2.dialogTop,'-')" value="上移">
      <input type="button" onclick="window.dialogArguments.s2.dialogLeft=countNumber(window.dialogArguments.s2.dialogLeft,'-')" value="左移">
      <input type="button" onclick="window.dialogArguments.s2.dialogLeft=countNumber(window.dialogArguments.s2.dialogLeft,'+')" value="右移">
      <input type="button" onclick="window.dialogArguments.s2.dialogTop=countNumber(window.dialogArguments.s2.dialogTop,'+')" value="下移">
  
      以上关键部份是:
        窗口命名方式:var s1=showModelessDialog('控制.htm',window,"dialogTop:1px;dialogLeft:1px")
        变量访问方式:window.dialogArguments.s2.dialogTop
  
      这个例子只是现实showModelessDialog与showModelessDialog之间的位置操作功能,通过这个原理,在showModelessDialog之间相互控制各自的显示页面,传递变量和数据等。
    
    基本介绍:
               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
    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。
    
    参数传递:
    1.     要想对话框传递参数,是通过vArguments来进行传递的。类型不限制,对于字符串类型,最大为4096个字符。也可以传递对象,例如:
    -------------------------------
    parent.htm
    
    modal.htm
    
    -------------------------------
    2.     可以通过window.returnValue向打开对话框的窗口返回信息,当然也可以是对象。例如:
    ------------------------------
    parent.htm
    
    (一)showModalDialog使用例子,父窗口向子窗口传递值,子窗口设置父窗口的值,子窗口关闭的时候返回值到父窗口.
    
    farther.html
    ---------------------------
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> New Document </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="">
    <META NAME="Keywords" CONTENT="">
    <META NAME="Description" CONTENT="">
    
    </HEAD>
  
    <BODY>
    <br>传递到父窗口的值:<input id="txt9" type="text" value="3333333333333"><br>
    返回的值:<input id="txt11" type="text"><br>
    子窗口设置的值:<input id="txt10" type="text"><br>
  
    
    <input type ="button" value="openChild" onclick="openChild()">
    </BODY>
    </HTML>
    ---------------------------------------------------------------
    child.html
    --------
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> New Document </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="">
    <META NAME="Keywords" CONTENT="">
    <META NAME="Description" CONTENT="">
    <meta http-equiv="Expires" CONTENT="0">
    <meta http-equiv="Cache-Control" CONTENT="no-cache">
    <meta http-equiv="Pragma" CONTENT="no-cache">
  
</HEAD>
    <BODY>
    <br>父窗口传递来的值:<input id="txt0" type="text"><br>
    输入要设置父窗口的值:<input id="txt1" type="text"><input type ="button" value="设置父窗口的值" onclick="setFather()"><br>
    输入返回的值:<input id="txt2" type="text"><input type ="button" value="关闭切返回值" onclick="retrunValue()">
    <input type ="button" value="关闭刷新父窗口" onclick="">
  
    </BODY>
    </HTML>
  
    
    
    ----------------------------
    说明:
    由于showModalDialog缓存严重,下面是在子窗口取消客户端缓存的设置.也可以在服务器端取消缓存,参考:
    http://adandelion.cnblogs.com/articles/252137.html
    <meta http-equiv="Expires" CONTENT="0">
    <meta http-equiv="Cache-Control" CONTENT="no-cache">
    <meta http-equiv="Pragma" CONTENT="no-cache">
    ------------------------------------------------------------------------------------------------------------------------
    (二)下面是关闭刷新父窗口的例子
    
    farther.html
    ---------------------------
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> New Document </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="">
    <META NAME="Keywords" CONTENT="">
    <META NAME="Description" CONTENT="">
    
    </HEAD>
  
    <BODY>
    <br>传递到父窗口的值:<input id="txt9" type="text" value="3333333333333"><br>
    <input type ="button" value="openChild" onclick="openChild()">
    </BODY>
    </HTML>
    ----------------------------------------------------
    child.html
    --------
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> New Document </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="">
    <META NAME="Keywords" CONTENT="">
    <META NAME="Description" CONTENT="">
    <meta http-equiv="Expires" CONTENT="0">
    <meta http-equiv="Cache-Control" CONTENT="no-cache">
    <meta http-equiv="Pragma" CONTENT="no-cache">
  
</HEAD>
    <BODY>
    <br>父窗口传递来的值:<input id="txt0" type="text"><br>
  
    <input type ="button" value="关闭刷新父窗口" onclick="winClose(1)">
    <input type ="button" value="关闭不刷新父窗口" onclick="winClose(0)">
  
    </BODY>
    </HTML>
  
    --------------------------
    说明
    1.下面是取消客户端缓存的:
    <meta http-equiv="Expires" CONTENT="0">
    <meta http-equiv="Cache-Control" CONTENT="no-cache">
    <meta http-equiv="Pragma" CONTENT="no-cache">
    也可以在服务器端取消缓存,参考:
    http://adandelion.cnblogs.com/articles/252137.html
  
    2.向父窗口传递阐述在ASP.NET中也可以是用aaa.aspx?id=1的方式传递.
    
    3.不刷新父窗口的话在父窗口中直接这样一来设置可以.
    
    4.在子窗口中若要提交页面的话要加入:,这样就不会打开新窗口了.
    <head>
    <base target="_self">
    </HEAD>
  










