當前位置:首頁文章首頁 IT學院 Javascript

js實現(xiàn)模態(tài)對話框

作者:  來源:  發(fā)布時間:2011-6-21 11:13:35  點擊:

這篇文章提供給大家分享學習的是關于js實現(xiàn)模態(tài)對話框經(jīng)驗分享,希望能夠幫助到大家。

首先,來說一下對話框 
對話框在Windows應用程序中使用非常普遍,許多應用程序的設定,與用戶交互需 
要通過對話框來進行,因此對話框是Windows應用程序中最重要的界面元素之一, 
是與用戶交互的重要手段。對話框是一個特殊的窗口,任何對窗口進行的操作( 
如移動、最大化、最小化等)也可以在對話框實施。 

對話框大致可以分為以下兩種。 

(1)模態(tài)對話框:模態(tài)對話框彈出后,獨占了系統(tǒng)資源,用戶只有在關閉該對話 
框后才可以繼續(xù)執(zhí)行,不能夠在關閉對話框之前執(zhí)行應用程序其他部分的代碼。 
模態(tài)對話框一般要求用戶做出某種選擇。 

(2)非模態(tài)對話框:非模態(tài)對話框彈出后,程序可以在不關閉該對話框的情況下 
繼續(xù)執(zhí)行,在轉入到應用程序其他部分的代碼時可以不需要用戶做出響應。非模 
態(tài)對話框一般用來顯示信息,或者實時地進行一些設置。 

模態(tài)窗口在傳統(tǒng)編程語言中很常見,簡單的說就是,如果是模態(tài)的,就是打開一 
個子窗口,如果這個子窗口不關閉,就不能操作它的父窗口,原來程序暫停執(zhí)行 
,直到這個模態(tài)窗口關閉后才回到原來程序繼續(xù)。 

非模態(tài)的就是直接顯示出來,然后原來的程序繼續(xù)執(zhí)行下面的語句,而且其他窗 
口也呈可用狀態(tài)。 

模態(tài)對話框獨占了用戶的輸入,當一個模態(tài)對話框打開時,用戶只能與該對話框 
進行交互,而其他用戶界面對象收不到輸入信息。應用程序用到的大部分對話框 
都是模態(tài)對話框。 
通常瀏覽器中windwo.open或超鏈接彈出的新窗口就是非模式窗口,而模式窗口是 
類似alert那種必須關閉才能響應其他事件的窗口。 

明白了對話框的模態(tài)和非模態(tài),來看下邊 

在B/s結構應用程序的開發(fā)中,有時我們會希望使用者按下按鈕后開啟一個保持在 
原窗口前方的子窗口, 
在IE中,我們可以使用 
window.showModelessDialog()方法用來創(chuàng)建一個顯示HTML內容的非模態(tài)對話框。 
window.showModalDialog()方法用來創(chuàng)建一個顯示HTML內容的模態(tài)對話框,由于 
是對話框,因此它并沒有一般用window.open()打開的窗口的所有屬性。 


這里是window.showModalDialog彈出窗口的一個實例函數(shù):  

<script type="text/javascript">   
function openWin(src, width, height, showScroll){   
window.showModalDialog  
(src,"","location:No;status:No;help:No;dialogWidth:"+width+";dialogHeig  
ht:"+height+";scroll:"+showScroll+";");   
}   
</script>  

例:<span style="CURSOR: pointer" onclick="openWin  
(’http://www.deepteach.com’, ’500px’, ’400px’, ’no’)">點擊</span> 


需要注意的是FireFox瀏覽器中不支持showmodaldialog() ,這是因為在最初  
MozillaSuite 中(Firefox 是從這個套件衍生),是支持 showmodaldialog()  
的,不過后來發(fā)現(xiàn) showmodaldialog() 存在安全隱患,不久后就取消了對  
showmodaldialog() 的支持,這個事情還發(fā)生在 bug 194404 提交前。在想出更 
好的解決方案前,相信 Firefox 是不會提供對 showmodaldialog() 的支持的。 

打開彈窗只能使用window.open實現(xiàn)這樣的功能,window.open的語法如下 :  
oNewWindow = window.open( [sURL] [, sName] [, sFeatures] [, bReplace])  

只是,在Firefox下,window.open的參數(shù)中,sFeature多了一些功能設定,要讓 
FireFox下開啟的窗口跟IE的showModalDialog一樣的話, 
只要在sFeatures中加個modal=yes就可以了,也許可能是出于安全考慮modal=yes  
打開的并不是模式窗口 
范例如下:  
window.open  
(’openwin.html’,'newWin’, 'modal=yes, width=200,height=200,resizable=no, scrollbars=no’ );   

由于在firefox沒有showModalDialog方法。則用如下判斷來兼容兩種瀏覽器:  
<input type="button" value="打開對話框" onclick="showDialog('#')"/>  
  <SCRIPT   LANGUAGE="JavaScript">  
  <!--  
  function   showDialog(url)  
  {  
   if(   document.all   ) //IE  
   {  
   feature="dialogWidth:300px;dialogHeight:200px;status:no;help:no";  
   window.showModalDialog(url,null,feature);  
   }  
   else  
   {  
     //modelessDialog可以將modal換成dialog=yes  
   feature ="width=300,height=200,menubar=no,toolbar=no,location=no,";  
   feature+="scrollbars=no,status=no,modal=yes";    
   window.open(url,null,feature);  
   }  
  }  
  //-->  
</SCRIPT>

相關軟件

相關文章

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z