我正在开发一个使用的GreaseMonkey脚本window.showModalDialog
.
但在完成之前,我发现Firefox 29警告:
不推荐使用window.showModalDialog().请改用window.open().如需更多帮助, 请访问https://developer.mozilla.org/en-US/docs/Web/API/Window.open
但问题是window.open
需要UniversalBrowserWrite
特权才能打开模态窗口window.open
.
那么,为什么被window.showModalDialog
弃用?有没有不需要特权的API?
注意:我不想要一个虚假的模态对话框(比如jQuery的一个),我需要一个暂停JavaScript执行的真实模态.
如果您仍想使用此解决方案,可以使用我的showModalDialog polyfill using <dialog>
tag.
为什么不推荐使用window.showModalDialog?
来自http://tjvantoll.com/2012/05/02/showmodaldialog-what-it-is-and-why-you-should-never-use-it/,
一般来说,将本机对话框实现放入浏览器的想法是一个非常好的主意,但这
window.showModalDialog
是一个糟糕的实现,充满了问题和糟糕的浏览器支持.(......)请注意,(...)[使用模式对话框
showModalDialog
]是一个完整的HTML文档,而不是注入的片段.这是一个特征window.showModalDialog
.它实际上只是两个完全独立的窗口相互通信.事实上,你有两个独立的窗口和DOM,这意味着你不必担心JS和DOM冲突,如果你有很多错误的JavaScript与杂乱的全局范围,这是很有吸引力的.但大多数情况下,这只会增加不必要的复杂性,使浏览器实现变得复杂,并导致许多错误.(......)虽然模态对话框阻止用户与原始窗口交互很重要,但是没有理由不允许用户与其他选项卡或本机浏览器控件(后退/前进,收藏夹,地址栏等)进行交互.(...)这对最终用户来说实际上是一个很大的麻烦.(......)
调试体验
window.showModalDialog
非常糟糕.(...)你基本上被迫像1999年那样发出警报,以确定发生了什么.(......)目前没有主要的移动浏览器支持
window.showModalDialog
,所以如果您正在寻找任何类型的平板电脑/移动支持,您需要远离.
用什么代替?
HTML5引入了新<dialog>
元素,可用于显示对话框,包括模态对话框.
例如:
<dialog id="myDialog">
Foo bar
<button id="hide">Close</button>
</dialog>
<button id="show">Show Dialog</button>
var dialog = document.getElementById('myDialog');
document.getElementById('show').onclick = function() { dialog.showModal(); };
document.getElementById('hide').onclick = function() { dialog.close(); };
演示
问题是:
浏览器支持目前可以忽略不计,但有一个polyfill.
它不会暂停 JS执行.