亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

showModalDialog模態對話框的使用詳解以及瀏覽器兼容

2019-11-20 21:16:27
字體:
來源:轉載
供稿:網友

1.ModalDialog是什么?
showModalDialog是jswindow對象的一個方法,和window.open一樣都是打開一個新的頁面。
區別是:showModalDialog打開子窗口后,父窗口就不能獲取焦點了(也就是無法操作了)。
可以在子窗口中通過設置window.returnValue的值,讓父窗口可以獲取這個returnvalue.

2.一個例子
1)主窗口main.html,
2)在主窗口中通過showModalDialog的方式打開子窗口sub.html
3)在子窗口中設置returnValue返回給主窗口使用

main.html

復制代碼 代碼如下:

<HTML>
<HEAD>
<METANAME="GENERATOR"Content="oscar999">
</HEAD>
<script>
functionshowmodal()
{
varret=window.showModalDialog("sub.html?temp="+Math.random());
alert("subreturnvalueis"+ret);
}
</script>
<BODY>
<INPUTid=button1type=buttonvalue="opensub"name=button1onclick="showmodal();">
</BODY>
</HTML>

sub.html
復制代碼 代碼如下:

<HTML>
<HEAD>
<METANAME="GENERATOR"Content="oscar999">
</HEAD>
<script>
functionreturnMain()
{
window.returnValue="returnfromsub";
window.close();
}
</script>
<BODY>
<INPUTid=button1type=buttonvalue="returnandclose"name=button1onclick="returnMain()">
</BODY>
</HTML>

特別說明:在main.html中showModalDialog的方法時,有使用到Math.random()的目的是避免緩存。

3.showModalDialog詳細使用
vReturnValue=window.showModalDialog(sURL[,vArguments][,sFeatures])
sURL
必選參數,類型:字符串。用來指定對話框要顯示的文檔的URL。
vArguments
可選參數,類型:變體。用來向對話框傳遞參數。傳遞的參數類型不限,包括數組等。對話框通過window.dialogArguments來取得傳遞進來的參數。
sFeatures
可選參數,類型:字符串。用來描述對話框的外觀等信息,可以使用以下的一個或幾個,用分號“;”隔開。
dialogHeight對話框高度,不小于100px,IE4中dialogHeight和dialogWidth默認的單位是em,而IE5中是px,為方便其見,在定義modal方式的對話框時,用px做單位。
dialogWidth:對話框寬度。
dialogLeft:距離桌面左的距離。
dialogTop:離桌面上的距離。
center:{yes|no|1|0}:窗口是否居中,默認yes,但仍可以指定高度和寬度。
help:{yes|no|1|0}:是否顯示幫助按鈕,默認yes。
resizable:{yes|no|1|0}[IE5+]:是否可被改變大小。默認no。
status:{yes|no|1|0}[IE5+]:是否顯示狀態欄。默認為yes[Modeless]或no[Modal]。
scroll:{yes|no|1|0|on|off}:指明對話框是否顯示滾動條。默認為yes。

還有幾個屬性是用在HTA中的,在一般的網頁中一般不使用。
dialogHide:{yes|no|1|0|on|off}:在打印或者打印預覽時對話框是否隱藏。默認為no。
edge:{sunken|raised}:指明對話框的邊框樣式。默認為raised。
unadorned:{yes|no|1|0|on|off}:默認為no。

4.瀏覽器兼容
但是并不是所有瀏覽器對兼容這樣的用法。
在Chrome中運行上面的例子的話,父窗口可以任意獲取焦點,效果和window.open一樣,而且獲取的returnVale也是undefined.
以下是各主流瀏覽器對此方法的支持狀況。

瀏覽器是否支持狀態
IE9 
Firefox13.0 
safari5.1 
chrome19.0×并不是模態對話框,而是open了一個新窗體
Opera12.0×什么也發生,連個窗體都不彈

如果有傳入vArguments這個參數為window的話:

復制代碼 代碼如下:

var ret = window.showModalDialog("sub.html?temp="+Math.random(),window);

則在子窗口中,以下的值為:
瀏覽器模態對話框window.openerwindow.dialogArgumentsreturnValue 
 IE9 ○ undefined [object Window] ○
 Firefox13.0 ○ [objectWindow] [object Window] ○
 safari5.1 ○ [objectWindow] [object Window] ○
 chrome19.0 × [objectWindow] undefined ×

注意一下Firefox瀏覽器下,子窗體假如刷新的話window.dialogArguments照樣會丟失,變成undefined。以上結果中我們可以看出返回值returnValue就只有chrome瀏覽器返回的是undefined,其他瀏覽器都沒有問題

5.如何解決Chrome的兼容問題。
方向是:設置window.opener.returnValue=""
main.html

復制代碼 代碼如下:

<HTML> 
<HEAD> 
<META NAME="GENERATOR" Content="oscar999"> 
</HEAD> 
<script>
function showmodal()
{
  var ret = window.showModalDialog("sub.html?temp="+Math.random(),window);
  //for Chrome
  if(ret==undefined)
  {
    ret = window.returnValue;
  }
  alert("sub return value is "+ret);
}
</script>
<BODY> 
<INPUT id=button1 type=button value="open sub" name=button1 onclick="showmodal();"> 
</BODY> 
</HTML>

sub.html
復制代碼 代碼如下:

<HTML> 
<HEAD> 
<META NAME="GENERATOR" Content="oscar999"> 
</HEAD> 
<script>
function returnMain()
{
  if(window.opener!=undefined)
  {
    window.opener.returnValue = "return from sub";
  }else{
    window.returnValue = "return from sub";
  }
  window.close();
}
</script>
<BODY> 
<INPUT id=button1 type=button value="return and close" name=button1 onclick="returnMain()"> 
</BODY> 
</HTML>

這里是判斷某些對象是否為defined來區分瀏覽器。當然,也可以判斷瀏覽器的類型的方式進行

這里是借用了父窗口的returnValue來使用, 如果父窗口的returnValue也用其他用途是可以使用替換的方式進行了, as:
var oldValue  = window.returnValue;
var newValue = showModalDialog()
window.returnValue = oldValue 

6.需要特別注意的是,Chrome下的測試需要把html 文件放入到web server(Tomcat,...)下通過http url 訪問測試。否則就不成功了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97在线看免费观看视频在线观看| 色综合久久久888| 欧美激情videos| 亚洲国模精品私拍| 亚洲一区国产精品| 92看片淫黄大片看国产片| 97婷婷涩涩精品一区| 欧美第一淫aaasss性| 97热在线精品视频在线观看| 成人中文字幕在线观看| 亚洲国产精彩中文乱码av在线播放| 在线观看久久av| 色香阁99久久精品久久久| 日韩精品在线免费| 亚洲第一福利在线观看| 一区二区在线视频播放| 精品国产拍在线观看| 国产精品999999| 一区二区三区四区在线观看视频| 国产精品丝袜久久久久久不卡| 正在播放亚洲1区| 亚洲国内精品视频| 在线播放国产一区中文字幕剧情欧美| 美女撒尿一区二区三区| 久久久久久中文| 欧美一级电影在线| 91久久精品视频| 久久久噜噜噜久久中文字免| 国产精品免费视频xxxx| 91精品久久久久久久久久久| 亚洲电影成人av99爱色| 国产视频福利一区| 久久久av免费| 亚洲精品午夜精品| 亚洲a级在线播放观看| 日韩美女激情视频| 一区二区三区四区视频| 日韩大陆欧美高清视频区| 亚洲精品国偷自产在线99热| 欧美精品在线观看| 欧美精品久久久久久久免费观看| 亚洲影视九九影院在线观看| 日韩欧美视频一区二区三区| 欧美精品在线播放| 中文字幕v亚洲ⅴv天堂| 日韩a**站在线观看| 国产精品自产拍在线观| 欧美理论片在线观看| 精品美女永久免费视频| 日韩中文字幕不卡视频| 国产成人精品在线播放| 欧洲精品毛片网站| 欧美一级大片在线观看| 国产精品日韩欧美综合| 国产91成人video| 人妖精品videosex性欧美| 91精品国产乱码久久久久久蜜臀| 亚洲国产91色在线| 欧美日韩国产精品专区| 日韩精品视频在线播放| 91精品久久久久久久久中文字幕| 国产一区二区三区网站| 亚洲欧美日韩爽爽影院| 欧美成人午夜免费视在线看片| 亚洲欧洲偷拍精品| 久久久久国产视频| 一区二区三区国产在线观看| 久久中文字幕视频| 亚洲国产另类久久精品| 欧美激情视频网| 91热福利电影| 国产精品a久久久久久| 美乳少妇欧美精品| 中文字幕一区日韩电影| 亚洲美女视频网站| 亚洲国产精品推荐| 热门国产精品亚洲第一区在线| 日韩av在线不卡| 8x海外华人永久免费日韩内陆视频| 青青在线视频一区二区三区| 亚洲黄色av女优在线观看| 精品国产1区2区| 久久久久久久一| 乱亲女秽乱长久久久| 一区二区三区四区精品| 国产精品福利小视频| 欧美性xxxx18| 亚洲图片在线综合| 大量国产精品视频| 亚洲天堂影视av| 亚洲香蕉成人av网站在线观看| 国产网站欧美日韩免费精品在线观看| 日韩精品免费在线观看| 亚洲欧洲午夜一线一品| 国产成人精品久久久| 九九九久久久久久| 亚洲国产精品久久久| 两个人的视频www国产精品| 亚洲人线精品午夜| 亚洲大胆人体在线| 久久久久久久999| 成人午夜两性视频| 亚洲欧美日韩国产精品| 亚洲综合在线中文字幕| 美女黄色丝袜一区| 欧美高清视频一区二区| 中日韩美女免费视频网址在线观看| 国产在线拍偷自揄拍精品| 欧美又大又硬又粗bbbbb| 亚洲理论片在线观看| 精品久久久久久中文字幕| 欧美日韩免费一区| 成人免费看吃奶视频网站| 国产精品视频公开费视频| 久久久成人的性感天堂| 欧美精品手机在线| 欧美日韩国产精品一区二区三区四区| 91精品视频播放| 亚洲91精品在线观看| 午夜精品一区二区三区视频免费看| 欧美精品中文字幕一区| 亚洲三级免费看| 91午夜在线播放| 永久免费精品影视网站| 91久久久久久久久久久| 久久久久久97| 国产精品欧美一区二区三区奶水| 精品亚洲精品福利线在观看| 97在线视频免费观看| 国产香蕉精品视频一区二区三区| 久久精品99无色码中文字幕| 国产91热爆ts人妖在线| 国产午夜精品全部视频在线播放| 91欧美精品成人综合在线观看| 黑人与娇小精品av专区| 久久久久久国产精品久久| 日韩欧美一区二区三区久久| 国产一区二区三区视频| 91大神在线播放精品| 欧美高清视频在线播放| 国产欧美日韩精品在线观看| 国产一区二区日韩精品欧美精品| 精品久久香蕉国产线看观看亚洲| 国产日韩综合一区二区性色av| 欧美成人精品在线| 久久频这里精品99香蕉| 91精品国产综合久久男男| 亚洲大胆美女视频| 国产亚洲综合久久| 国产91免费看片| 欧美激情视频给我| 日韩黄色高清视频| 一区二区国产精品视频| 国产精品第七影院| 欧美床上激情在线观看| 欧美亚洲国产成人精品| 国产日本欧美一区二区三区在线| 亚洲国产婷婷香蕉久久久久久| 91久久夜色精品国产网站| 亚洲欧美日韩综合| xx视频.9999.com| 国产免费一区视频观看免费| 久久综合久久八八| 日韩视频免费大全中文字幕|