Chrome不支持showModalDialog模態(tài)對話框和無法返回returnValue問題的解決方法
What?模態(tài)對話框失效了?
上個禮拜修改測試一個后臺管理項目,在測試與各個瀏覽器兼容性的時候,發(fā)現(xiàn)在chrome瀏覽器下showModalDialog方法顯示的并不是模態(tài)對話框,就像新打開一個頁面一樣,父窗口仍然可以隨意獲取焦點,并可以打開多個窗體,而且返回值returnValue也無法返回,一直是undefined。這么多問題很令人頭疼,下面就各個主流最新版的瀏覽器進(jìn)行了一下測試。
瀏覽器 | 是否支持 | 狀態(tài) |
IE9 | ○ | |
Firefox13.0 | ○ | |
safari5.1 | ○ | |
chrome19.0 | × | 并不是模態(tài)對話框,而是open了一個新窗體 |
Opera12.0 | × | 什么也發(fā)生,連個窗體都不彈 |
Chrome到底打開的是什么
因為打開的不是模態(tài)對話框,而是像open了一個新窗體一樣,那只要驗證一下子窗體window.opener是否為空就明白了。
<script type="text/javascript"> alert(window.opener); </script>
在chrome中,顯示的是一個[object window]對象,而IE則是undefined?,F(xiàn)在知道原來chrome將showModalDialog當(dāng)作window.open來處理了。也就是說我們完全可以用window.opener來操作chrome瀏覽器下子窗體。這里還發(fā)現(xiàn)個很有趣的現(xiàn)象,firefox中測試window.opener也并不為空,于是我又測試了下使用showModalDialog在子窗體中關(guān)于window.opener和window.dialogArguments在各個瀏覽器里的狀況,由于Opera瀏覽器連個窗體都不彈,下面測試就剔除它了。
說明下父窗體的showModalDialog的方法中arguments傳遞是window對象,下面是測試的結(jié)果:
瀏覽器 | 模態(tài)對話框 | window.opener | window.dialogArguments | returnValue |
IE9 | ○ | undefined | [object Window] | ○ |
Firefox13.0 | ○ | [object Window] | [object Window] | ○ |
safari5.1 | ○ | [object Window] | [object Window] | ○ |
chrome19.0 | × | [object Window] | undefined | × |
以上是我測試的結(jié)果,各個瀏覽器所支持的程度還是不一樣的。還要說一下Firefox瀏覽器下,子窗體假如刷新的話window.dialogArguments照樣會丟失,變成undefined。以上結(jié)果中我們可以看出返回值returnValue就只有chrome瀏覽器返回的是undefined,其他瀏覽器都沒有問題。那該如何解決這個問題呢?
解決returnValue問題
通過以上的種種測試,我們已經(jīng)知道chrome的showModalDialog方法很像執(zhí)行了window.open方法,那么我們可以利用window.opener來實現(xiàn)window.returnValue的功能。
注意:temp=Math.random()這個隨機參數(shù)是為了解決緩存問題,不少朋友測試出undefined是因為是緩存的問題。 追加于2012-10-17
父窗體部分js代碼:
window.onload = function () { var returnValue = window.showModalDialog("son.html?temp=" + Math.random(), window); //for chrome if (returnValue == undefined) { returnValue = window.returnValue; } alert(returnValue); }
子窗體部分js代碼:
if (window.opener != undefined) { //for chrome window.opener.returnValue = "opener returnValue"; } else { window.returnValue = "window returnValue"; } window.close();
這樣也在IE,FireFox,Chrome,Safari等瀏覽器下都可以通用了。
最后
最后有人要問那該如何實現(xiàn)模態(tài)對話框呢?我覺得應(yīng)該是可以用一些js技巧去實現(xiàn)的,但是我不并推薦這樣做,我也查詢了很資料都不能很好的解決這個問題。當(dāng)然,也可以有其他一些思路,比如為了不彈出更多的窗體,可以在點擊打開窗體的時候?qū)⒛莻€open按鈕設(shè)置為不可用,只有關(guān)閉了子窗體再設(shè)置成可用。這些大家都可以自己去實踐下,或許有更好的方法。
最后我想說的是在當(dāng)今的網(wǎng)頁設(shè)計中很流行用div在頁面內(nèi)去模擬一個窗體,樣式自定義,交互都很不錯,不一定非要用模態(tài)窗體,如何模擬網(wǎng)上一大把,今天就寫到這里吧,有什么錯誤的地方請大家多指正~~
- js模式化窗口問題![window.dialogArguments]
- window.dialogArguments 使用說明
- JS在Chrome瀏覽器中showModalDialog函數(shù)返回值為undefined的解決方法
- 谷歌showModalDialog()方法不兼容出現(xiàn)對話窗口的解決辦法
- 谷歌瀏覽器不支持showModalDialog模態(tài)對話框的解決方法
- showModalDialog模態(tài)對話框的使用詳解以及瀏覽器兼容
- showModalDialog在谷歌瀏覽器下會返回Null的解決方法
- window.showModalDialog兩次加載問題清除緩存方法
- Chrome中模態(tài)對話框showModalDialog返回值問題的解決方法
相關(guān)文章
Bootstrap企業(yè)網(wǎng)站實戰(zhàn)項目4
這篇文章主要為大家分享了Bootstrap企業(yè)網(wǎng)站實戰(zhàn)項目,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10由淺入深講解Javascript繼承機制與simple-inheritance源碼分析
Javascript語言對繼承實現(xiàn)的并不好,需要工程師自己去實現(xiàn)一套完整的繼承機制。下面我們由淺入深的系統(tǒng)掌握使用javascript繼承的技巧,對javascript繼承相關(guān)知識感興趣的朋友一起看看吧2015-12-12javascript實現(xiàn)貪吃蛇經(jīng)典游戲
這篇文章主要為大家詳細(xì)介紹了javascript實現(xiàn)貪吃蛇經(jīng)典游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04javascript中JSON.parse()與eval()解析json的區(qū)別
這篇文章主要介紹了javascript中JSON.parse()與eval()解析json的區(qū)別,詳細(xì)描述了json格式數(shù)據(jù)的操作技巧,并結(jié)合實例形式對比分析了使用JSON.parse()與eval()解析json的區(qū)別,需要的朋友可以參考下2016-05-05JavaScript數(shù)組特性與實踐應(yīng)用深入詳解
這篇文章主要介紹了JavaScript數(shù)組特性與實踐應(yīng)用,較為深入而詳細(xì)的分析了javascript數(shù)組的功能、屬性、使用方法及操作注意事項,需要的朋友可以參考下2018-12-12JS實現(xiàn)的計數(shù)排序與基數(shù)排序算法示例
這篇文章主要介紹了JS實現(xiàn)的計數(shù)排序與基數(shù)排序算法,結(jié)合實例形式簡單分析了計數(shù)排序與基數(shù)排序的原理與JS實現(xiàn)技巧,需要的朋友可以參考下2017-12-12js實現(xiàn)rem自動匹配計算font-size的示例
本篇文章主要介紹了js實現(xiàn)rem自動匹配計算font-size的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11