Javascript操作模态与非模态对话框

Javascript操作模态与非模态对话框

我们知道,对话框一般分为两种类型:模态类型(modal)与非模态类型(modeless)。所谓模态对话框,就是指除非采取有效的关闭手段,用户的鼠标焦点或者输入光标将一直停留在其上的对话框。非模态对话框则不会强制此种特性,用户可以在当前对话框以及其他窗口间进行切换。本文介绍如何使用javascript语言来创建这两种类型的对话框、控制其大小和位置、改变其外观以及在对话框间的数据传递。  
本文的所有例程中,从层次上涉及到2个HTML页面。我们把第一个页面叫做caller页面,第二个页面叫做callee页面。也就是说,在caller页面执行代码创建生成callee页面。  
一、创建模态和非模态对话框  
首先,我们举个例子来快速了解一下什么是模态与非模态。在caller.htm中,我们输入以下代码:  
onclick=”fnOpenModal()”>  


  
onclick=”fnOpenModeless()”>  
  
function fnOpenModal(){  
window.showModalDialog(“callee.htm”)  
}  
function fnOpenModeless(){  
window.showModelessDialog(“callee.htm”)  
}  
  
在浏览器中打开caller.htm,点击“创建模态对话框”按钮,将会出现一个对话框窗口,其中的内容是callee.htm。你会看到,除了关闭这个新窗口,无论怎样我们也不能将其他的窗口设置为“当前活动”窗口,这个一直是活动状态的窗口类型就是模态类型。关闭这个模态对话框,回到caller.htm页面,点击“创建非模态对话框”,出现一个包含callee.htm页面的对话框窗口。这回有所不同,鼠标可以转移到其他地方使另外的窗口成为“当前活动”状态,这就是非模态的概念。  
接下来,我们看看创建模态对话框与非模态对话框的相关语法:  
创建模态对话框:  
vReturnvalue = window.showModalDialog(sURL [, vFreeArgument] [, sOrnaments]);  
创建非模态对话框:  
vReturnvalue = window.showModelessDialog(sURL [, vFreeArgument] [, sOrnaments]);  
从上面的语法我们得知:除了名字有所区别外,参数种类与含义都相同。以下是各参数的含义:  
· VReturnvalue:对于showModalDialog(),它表示被打开的对话框窗口设置的returnvalue属性值。对于showModelessDialog(),它表示新窗口对象。  
· VFreeArgument:这个参数可用于传递某种类型的数据到打开的对话框,数据可以是一个数值、字符串、数组或者一个对象类型。在新窗口中引用这个数值时,可通过新创建window对象的dialogArguments 属性。  
· SOrnaments:用这个参数指定新窗口的外观。可选择的窗口属性有很多种,当有多种控制需求时,将相关内容用一个字符串连接起来,其间用分号隔开。以下是可选择的属性种类:  
o dialogHeight: sHeight  
o dialogLeft: sXpos  
o dialogTop: sYpos  
o dialogWidth: sWidth  
o center: ( yes | no | 1 | 0 | on | off )  
o dialogHide: ( yes | no | 1 | 0 | on | off )  
o edge: ( sunken | raised )  
o help: ( yes | no | 1 | 0 | on | off )  
o resizable: ( yes | no | 1 | 0 | on | off )  
o scroll: ( yes | no | 1 | 0 | on | off )  
o status: ( yes | no | 1 | 0 | on | off )  
除了以上属性外,我们还可以加入更加丰富的CSS控制。 以下我们来详细解释如何应用这些属性。  
二、控制对话框大小和位置  
控制对话框的大小和位置涉及到5个方面:高度(dialogHeight)、宽度(dialogWidth)、相对于桌面左上角的x坐标(dialogLeft)、y坐标(dialogTop)以及是否让对话框窗口居中(center)。由于不同版本的Internet Explorer浏览器处理的默认度量单位并非一致,所以我们在指定高度、宽度等大小时,最好是同时设置好单位。单位种类包括很多,比如cm、mm、in、pt、pc、px。请注意:最小的高度值是100px。  
下面的代码将打开一个高200px、宽800px的对话框:  
window.showModalDialog(’callee.htm’,’’,’dialogHeight:200px;dialogWidth:800px’);  
我们注意到,打开的新窗口会在桌面中处于居中的位置,这也正是居中属性(center)的默认值。居中属性(center)的可取值包括yes、no、1、0、on和off,含义一目了然。执行以下代码,看看关闭居中属性后新窗口的位置:  
window.showModalDialog(’callee.htm’,’’,’dialogHeight:200px;dialogWidth:800px;center:no’);  
我们看到,新窗口紧挨者桌面的左上角打开。当然,我们可以使用dialogLeft和dialogTop 属性来精确定义新窗口的打开位置。下面的代码将在相对于桌面左上角的x位置300px和y位置500px处打开新窗口:  
window.showModalDialog(’callee.htm’,’’,’dialogHeight:200px;dialogWidth:800px;dialogLeft:300; 
dialogTop:500’)  
注意,即使指定了居中属性,但如果同时设置了dialogLeft和dialogTop属性值,那么窗口位置将遵从后者。试一试执行下面的代码:  
window.showModalDialog(’callee.htm’,’’,’dialogHeight:200px;dialogWidth:800px;dialogLeft:300; 
dialogTop:500;center:yes’)  
三、改变对话框外观  
对话框的外观控制包括从窗口边缘风格(edge)、是否存在滚动条(scroll)、是否包含上下文关联提示图标(help)、是否显示状态栏(status)以及是否可以改变窗口大小(resizable)等方面。默认情况下,新打开的窗口是大小不可改变的、边缘风格为凸起、在新窗口右上角显示一个上下文关联提示图标、存在滚动条,比如:  

edge的可取值为sunken(凹陷)和raised(凸起),status、help、resizeable和scroll的可取值都是yes、no、1、0、on和off,其含义一目了然。  
下面的代码将去除上下文关联提示图标、不显示状态栏、窗口边缘风格为凹陷:  
showModelessDialog(“callee.htm”,”",”status:0;help:0;edge:sunken”);  

四、从caller页面传递数据到callee页面  
上面我们介绍了创建模态和非模态窗口的语法以及如何控制新窗口的大小、位置和外观,接下来我们研究一下实际应用中更实用的功能:如何从caller页面传递数据到callee页面。  
从caller页面传递给callee页面的数据分为3类:传递值、传递数组引用以及传递对象,它们都是通过showModalDialog()和showModelessDialog()的第2个参数实现的。  
(一)传递值类型数据  
在caller.htm页面中输入以下代码:  
onclick=”fnOpenModal()”>  


  
onclick=”fnOpenModeless()”>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值