当前位置: 首页 > 图文教程 > 网络编程 > Javascript > IE中非模式对话框(showModelessDialog)应用

Javascript
JQuery 学习笔记 选择器之四
JQuery 学习笔记 选择器之五
JQuery 学习笔记 选择器之六
JQuery CSS样式控制 学习笔记
用js模仿word格式刷功能实现代码 [推荐]
运用jquery实现table单双行不同显示并能单行选中
jqPlot jquery的页面图表绘制工具
jquery tools之tabs 选项卡/页签
jquery tools之tooltip
浅析Javascript原型继承 推荐
JQuery UI皮肤定制
实现lightBox时的样式与行为分离减少JS
JQuery 表格操作(交替显示、拖动表格行、选择行等)
javascript 进度条 实现代码
Javascript this指针
jquery imgareaselect 使用利用js与程序结合实现图片剪切
javascript 写的一个简单的timer
javascript 处理HTML元素必须避免使用的一种方法
Javascript 验证上传图片大小[客户端]
jQuery 隔行换色 支持键盘上下键,按Enter选定值

Javascript 中的 IE中非模式对话框(showModelessDialog)应用


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-10   浏览: 379 ::
收藏到网摘: n/a

非模式对话框是IE的一种窗口形式,打开非模式对话框后,在其被关闭之前,主调窗口不会继续解析其后的htm代码,同时主调窗口也不会被选中。

 

主调窗口与非模式窗口的信息传递

1.函数调用传递方式

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

 

主调窗口通过showModelessDialog方法的第二个参数 vArguments 向非模式窗口传递参数,该参数可以是数组,也可以是DOM对象。

非模式窗口通过window.dialogArguments 来提取传递过来的参数,若是数组,则用window.dialogArguments[i]来表示数组的第i个参数

非模式窗口通过window.returnValue向主调窗口传回值,这个值作为showModelessDialog 方法的返回值被主调窗口接收。

 

2.窗口操作传递方式

非模式窗口通过主调窗口传递过来window对象直接操纵主调窗口的元素

此时showModelessDialog 需要将主调窗口的 window 对象作为参数传出,在非模式窗口中即可取得主调窗口的窗口参考,用脚本可以直接对它操纵。

 

如主调窗口的调用代码如下:

showModelessDialog ("myDialog.htm",window,"status:false;dialogWidth:300px;dialogHeight:300px;edge:Raised; enter: Yes; help: No; resizable: No; status: No");

 

非模式窗口JScript代码如下,即可接收主调窗口的窗口对象

  var sData = window.dialogArguments;

 

接着就可以操作主调窗口的任意变量和函数了,如下:

  sData.sUserName = ‘Value from ModelessDialog’; // sUserName是主调窗口的全局变量

  sData.fnUpdate(); //fnUpdate是主调窗口的函数,在该函数中对sUserName变量做处理

 

这种方式下,主调窗口可以不通过普通返回值方式取得非模式窗口设定的数值

 

备注:

将主调窗口的Window对象传入非模式窗口是一种很灵活的操作手段。但在实践中发现,窗口对象只能是主调窗口自己的,你不能通过Dom对象结构,将其他帧页面(非主调窗口)的Window对象传入。但在非模窗口中可以根据传入的主调窗口的Window对象,通过Dom对象结构引用到非主调窗口的任何对象。

 

关于非模式对话框的参数设置sFeatures

http://msdn.microsoft.com/workshop/samples/author/dhtml/refs/showModelessDialog.htm