`
datuo
  • 浏览: 82290 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

JS高级应用:操作模态与非模态对话框

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

function fnOpenModeless(){ 
window.showModelessDialog("callee.htm") 

</script> 
在浏览器中打开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页面中输入以下代码: 
<INPUT TYPE="button" value="创建模态对话框" onclick="fnOpenModal()"> 
<br><br> 
<INPUT TYPE="button" value="创建非模态对话框" onclick="fnOpenModeless()"> 
<script language="javascript"> 
<!-- 
function fnOpenModal(){ 
window.showModalDialog("callee.htm","打开了一个新模态窗口") 

function fnOpenModeless(){ 
window.showModelessDialog("callee.htm","打开了一个新非模态窗口") 

// --> 
</script> 
在callee.htm页面中输入以下代码: 
<SCRIPT LANGUAGE="javascript"> 
<!-- 
alert(dialogArguments); 
// --> 
</SCRIPT> 
在浏览器中打开caller.htm,点击任意一个按钮,我们将首先看到如下的提示信息框: 

然后才出现新窗口。这种情况下,callee.htm页面中的window对象的属性dialogArguments将对应于caller.htm页面中的"打开了一个新模态窗口"或者"打开了一个新非模态窗口"。如果直接打开callee.htm,将会出现错误提示。 
(二)传递数组引用类型数据 
第一种值类型数据的传递中,在callee.htm页面中只能读取caller.htm页面的传递数据。当需要对caller.htm页面的传递内容进行修改时,就需使用到数组引用类型的传递方式。 
首先,在caller.htm页面中输入以下代码: 
<INPUT TYPE="button" value="创建模态对话框" onclick="fnOpenModal()"> 
<br><br> 
<INPUT TYPE="button" value="创建非模态对话框" onclick="fnOpenModeless()"> 
<script language="javascript"> 
<!-- 
var a = new Array; 
a[0]="first"; 
a[1]="second"; 
a[2]="third"; 
function fnOpenModal(){ 
window.showModalDialog("callee.htm",a) 

function fnOpenModeless(){ 
window.showModelessDialog("callee.htm",a) 

// --> 
</script> 
然后在callee.htm页面中输入以下代码: 
<SCRIPT LANGUAGE="javascript"> 
<!-- 
a = dialogArguments; 
alert(a); 
a[0] = "fourth"; 
// --> 
</SCRIPT> 
最后,在浏览器中打开caller.htm,点击任意一个按钮,我们将首先看到如下的对话框: 

接着关闭这个对话框以及新打开的窗口,再次点击一个按钮,又出现一个对话框: 

从运行结果我们看到,在caller.htm页面中通过对数组a的地址引用,就可以实现在callee.htm中修改数组a的内容。 
注意在callee.htm中要首先建立对传递数据的附值:a = dialogArguments。 
(三)传递对象类型数据 
在caller.htm和callee.htm中传递数据的最有效方式是通过对象方式进行,这不仅能实现从caller.htm到callee.htm的传递,还能从callee.htm传递到caller.htm。而且,我们还可以在caller.htm中定义对象的方法,再在callee.htm中使用它们。实际上,我们可以将caller.htm的window对象传递给callee.htm,这样就可以在callee.htm中访问caller.htm的变量及函数。 
来看看一个实际的例子。在caller.htm中输入以下代码: 
<HTML> 
<HEAD> 
<title>传递对象数据</title> 
<SCRIPT> 
var sColor=""; 
function callDialog() { 
showModelessDialog("callee.html",window,"status:false;dialogWidth:300px;dialogHeight:150px"); 

function update() 

oColor.innerText = sColor; 

</SCRIPT> 
</HEAD> 
<BODY> 
<P>输入你最喜欢的颜色: <SPAN ID="oColor" style="color:red;font-size:24">Yellow</SPAN></P> 
<INPUT TYPE="button" value="Display Modeless Dialog" onclick="callDialog()"> 
</BODY> 
</HTML> 
在callee.htm中输入以下代码: 
<HTML> 
<HEAD> 
<title>callee.html</title> 
<SCRIPT> 
function getInfoAndUpdate() { 
var callerWindowObj = dialogArguments; 
callerWindowObj.sColor = oEnterColor.value; 
callerWindowObj.update(); 

function cancel() { 
var callerWindowObj = dialogArguments; 
callerWindowObj.sColor = "Yellow"; 
callerWindowObj.update(); 

</SCRIPT> 
</HEAD> 
<BODY> 
输入你最喜欢的颜色:<INPUT ID=oEnterColor><BR><BR> 
<INPUT value="Apply" TYPE=button onclick="getInfoAndUpdate();"> 
<INPUT value="Ok" TYPE=button onclick="getInfoAndUpdate();window.close();"> 
<INPUT value="Cancel" TYPE=button onclick="cancel();window.close();"> 
</BODY> 
</HTML> 
在浏览器中打开caller.htm,点击“显示非模态对话框”按钮,出现新对话框: 

在对话框中输入其他颜色名称,点击“Apply”按钮后,执行callee.htm中的getInfoAndUpdate函数: 
function getInfoAndUpdate() { 
var callerWindowObj = dialogArguments; 
callerWindowObj.sColor = oEnterColor.value; 
callerWindowObj.update(); 

因为在caller.htm中传递给callee.htm的是对象类型数据window,所以经过第一条语句的附值,callerWindowObj就指向了caller.htm页面,然后就可以在callee.htm中按照callerWindowObj.xxx的形式引用caller.htm中的变量及函数:callerWindowObj.sColor = oEnterColor.value负责将callee.htm中输入的颜色名称传递给caller.htm中的变量sColor,然后再执行caller.htm中的 update()函数更新显示信息。 
可以看到,通过对象方式传递数据,功能很丰富强大,而且使用起来也不复杂。 
六、结 语 
以上对使用javascript语言操作模态和非模态对话框进行了详细介绍,相信你又掌握了在html页面中创建窗口的一个新技术。在实际应用中,模态对话框的功能比较实用,可用于必须让访问者阅读相关内容的情况下。另外,利用对象方式在窗口间传递数据,功能非常强大但使用却不复杂,是非常值得一用的技术。  
分享到:
评论

相关推荐

    模态对话框

    模态对话框是用户界面设计中的一个重要元素,它在计算机软件和移动应用中广泛使用,为用户提供了一种与系统交互的特殊方式。模态对话框是一种阻塞式窗口,当它打开时,用户必须先对其作出响应才能继续操作主应用程序...

    利用JavaScript创建模态非模态对话框

    例如,可以使用一个简单的按钮来显示和隐藏非模态对话框: ```javascript var nonModal = document.getElementById("nonModal"); document.getElementById("showBtn").addEventListener("click", function() { ...

    基于Extjs的模态对话框

    在Web应用开发中,用户界面的设计与交互是至关重要的,其中模态对话框(Modal Dialog)是一种常见的元素,用于向用户提供信息或者获取用户的输入。在本篇内容中,我们将深入探讨如何利用Extjs这一强大的JavaScript...

    javascript 弹出模态对话框

    JavaScript弹出模态对话框是前端开发中常见的一种交互方式,用于向用户显示重要的信息、询问用户或收集数据。模态对话框具有阻止用户在对话框关闭前与页面其他部分互动的特点,确保用户关注到对话框中的内容。在这个...

    子模态对话框关闭后刷新父模态对话框

    模态对话框(Modal Dialog)是一种常见的UI元素,它强制用户在完成特定任务或作出决定之前与之交互,不能操作背景页面。本话题关注的是如何在关闭子模态对话框后刷新其父模态对话框,这是一个典型的前端开发问题,...

    js的模态对话框

    模态对话框会阻止用户与页面其他部分的交互,直到对话框被关闭。这种功能在网页应用中广泛使用,比如确认操作、显示警告、输入验证等场景。 一、基本概念 1. 弹出框(Alert):最简单的模态对话框,通常用来显示...

    非模态对话框window.showModelessDialog简单示例

    非模态对话框在网页应用中是一个非常实用的设计元素,它允许用户在不关闭当前页面的情况下与一个独立的窗口进行交互。在JavaScript中,`window.showModelessDialog()`方法是实现这一功能的一种方式。这个方法可以...

    jquery模态对话框

    3. **jQuery的优势**:jQuery简化了JavaScript的DOM操作,使得创建和管理模态对话框变得容易,无需深入了解复杂的原生JavaScript代码。 ### 使用jQuery Boxy插件 1. **Boxy介绍**:Boxy是一款轻量级且高度可定制的...

    页面中弹出类似模态对话框

    在网页设计中,"页面中弹出类似模态对话框"是一种常见的用户界面元素,用于在用户与主页面交互时提供额外的信息或者需要用户确认的操作。这种对话框通常具有水晶质感,即透明度和光滑度的结合,为用户提供一种高级且...

    Bootstrap模态对话框的开发与应用.pdf

    Bootstrap 模态对话框的开发与应用 Bootstrap 模态对话框是 Web 开发中一个非常重要的组件,它可以用于显示警示信息、确认信息、输入信息等。在传统的 Web 开发中,jquery-confirm 是一个非常流行的模态对话框组件...

    js+div 超酷模态对话框[带提示声音]

    在网页设计中,模态对话框(Modal Dialog)是一种常见的用户交互元素,它可以在用户进行其他操作之前强制用户与对话框交互。这个“js+div 超酷模态对话框[带提示声音]”的资源,显然是一个利用JavaScript和HTML的div...

    ssm_ajaxsubmit-ajax提交-模态对话框-ajax上传文件

    在Web应用中,模态对话框常用于表单填写、确认操作或者展示详细信息等场景。Bootstrap框架提供了一种简单易用的模态组件,通过添加特定的HTML和CSS类,可以快速创建模态对话框,并通过JavaScript控制其显示和隐藏。 ...

    HTML5响应式模态框(模态对话框).zip

    HTML5响应式模态框(模态对话框)是一种网页设计技术,用于在用户与页面交互时提供一种中断当前操作并展示额外信息的方式。这种设计模式通常被用来显示警告、确认对话、表单输入或者任何需要用户关注的内容,而不...

    用javascript css div实现模态对话框

    用javascript css div实现弹出模态对话框,盖住下面的部分,上面的透明度改变

    JS 模态对话框和非模态对话框操作技巧汇总

    JavaScript中的模态对话框和非模态对话框是网页交互中常用的功能,它们用于提供额外的信息或与用户进行交互。模态对话框在打开时会阻止用户与页面其余部分的交互,直到对话框被关闭;而非模态对话框则允许用户在...

    javascript 页面刷新和模态对话框 学习总结 推荐哦

    本文介绍了JavaScript中页面刷新的多种方法以及如何在模态对话框中实现页面刷新。这些技术对于Web开发来说非常重要,可以帮助开发者更好地控制页面行为,提升用户体验。通过以上介绍,希望能帮助读者更好地理解和...

    html5模态对话框效果(10余种)

    模态对话框通常有一个遮罩层(modal overlay),确保用户在处理对话框前无法与主页面互动。在JavaScript中,可以监听事件(如点击按钮)来显示或隐藏对话框,同时设置遮罩层的透明度和点击行为。 4. **JavaScript...

    使用selenium测试showModalDialog模态对话框

    由于 Selenium 的执行依赖于JavaScript,因此在模态对话框打开时,Selenium 无法与对话框交互,导致测试无法正常进行。 面对这个问题,测试工程师需要采取一些变通的方法。对于两种不同类型的模态对话框应用,我们...

    修改 bootstrap 多个模态对话框 焦点冲突问题 BUG

    在使用Bootstrap框架构建Web应用程序时,常常会遇到多个模态对话框(Modal)同时存在的情况。这在功能上是很有用的,例如在一个页面上有多个独立的信息提示或表单提交。然而,当打开一个模态对话框后,再尝试打开另...

Global site tag (gtag.js) - Google Analytics