[b]
showModalDialog:[/b]模式窗口, 一种很特别的窗口,当它打开时,后面的父窗口的活动会停止,除非当前的模式子窗口关闭了, 才能操作父窗口.在做网页Ajax开发时,我们应该有时会用到它来实现表单的填写, 或做类似网上答题的窗口. 它的特点是,传参很方便也很强大,可直接调用父窗口的变量和方法.
[b]使用方法:
[/b]vReturnValue = window.showModalDialog(sURL [, vArguments] [,sFeatures])
[b]参数说明:[/b]
sURL--
必选参数,类型:字符串。用来指定对话框要显示的文档的URL。
vArguments--
可选参数,类型:变体。用来向对话框传递参数。传递的参数类型不限,包括数组等。对话框通过window.dialogArguments来取得传递进来的参数。
sFeatures--
可选参数,类型:字符串。用来描述对话框的外观等信息,可以使用以下的一个或几个,用分号“;”隔开。
[b]1.dialogHeight :
[/b] 对话框高度,不小于100px,IE4中dialogHeight和dialogWidth默认的单位是em,而IE5中是px,为方便其见,在定义modal方式的对话框时,用px做单位。
[b]2.dialogWidth:[/b]
对话框宽度。
[b]3.dialogLeft:
[/b] 离屏幕左的距离。
[b]4.dialogTop:
[/b] 离屏幕上的距离。
[b]5.center: {yes | no | 1 | 0 }:
[/b] 窗口是否居中,默认yes,但仍可以指定高度和宽度。
[b]6.help: {yes | no | 1 | 0 }:
[/b] 是否显示帮助按钮,默认yes。
[b]7.resizable: {yes | no | 1 | 0 }
[/b] [IE5+]:是否可被改变大小。默认no。
[b]8.status: {yes | no | 1 | 0 }
[/b] [IE5+]:是否显示状态栏。默认为yes[ Modeless]或no[Modal]。
[b]9.scroll:{ yes | no | 1 | 0 | on | off }:
[/b] 指明对话框是否显示滚动条。默认为yes。
下面几个属性是用在HTA中的,在一般的网页中一般不使用。
[b]10.dialogHide:{ yes | no | 1 | 0 | on | off }:
[/b] 在打印或者打印预览时对话框是否隐藏。默认为no。
[b]11.edge:{ sunken | raised }:
[/b]指明对话框的边框样式。默认为raised。
[b]12.unadorned:{ yes | no | 1 | 0 | on | off }:
[/b] 默认为no。
[b]
FOR example:
[/b]parent.html
<script>
function setname(res){
document.getElementByIdx_x("name").value=res;
}
function selectTp(){
//把父窗口的setname函数传给子窗口window.showModalDialog('child.html',setname,'dialogWitdh:300px;dialogHeight:300px;center:yes;');
}
</script>
<input type="button" value="提交" onclick="selectTp()"/>
<input type="text" id="name" name='name'/>
child.html
<SCRIPT LANGUAGE="JavaScript">
<!--
function setName(){
var win="";
if(window.dialogArguments!=null)
{
//子窗口获取父窗口的setname函数,并操作赋值
win=window.dialogArguments;
win('Jone');
}
this.close();
}
//-->
</SCRIPT>
<input type="button" value="给父窗口赋值" onclick="setName()"/>