3

单击按钮时,我必须打开一个窗口,作为使用 JavaScript 的模式对话框。我使用过window.open,但它显示了两个实例,父页面和弹出页面。当弹出页面打开时,不允许用户点击父页面。

function openWindow() {
  var w = 950;
  var h = 350;
  var t = 0;
  var l = 0;
  var scrollbars = 1;
  var modal = 'yes';

  var reportWindow = window.open("Search.aspx" + '', '', "width=" + w + ",height=" + h + ",left=" + l + ",top=" + t + ',scrollbars=' + scrollbars + 'modal' + modal);
  reportWindow.focus();
}
4

2 回答 2

8

你的代码行,

reportWindow = window.open("Search.aspx" + '', '', "width=" + w + ",height=" + h + ",left=" + l + ",top=" + t + ',scrollbars=' + scrollbars + 'modal' + modal);

模态后缺少“=”符号。它应该是,

reportWindow = window.open("Search.aspx" + '', '', "width=" + w + ",height=" + h + ",left=" + l + ",top=" + t + ',scrollbars=' + scrollbars + 'modal=' + modal);

要将窗口作为对话框打开,

 <html>
    <body>
    <script language="JavaScript">
    function openWindow() {
       if (window.showModalDialog) {
window.showModalDialog("http://example.com","name",
"dialogWidth:255px;dialogHeight:250px");
} else {
window.open('http://example.com','name',
'height=255,width=250,toolbar=no,directories=no,status=no, linemenubar=no,scrollbars=no,resizable=no ,modal=yes');
}
    } 
    </script>
    <button onclick="openWindow();">Open window</button>
    </body>
    </html>

如果上述代码不起作用,请使用 jQuery 模态对话框。您可以使用 iframe 将任何 url 加载到对话框中。

于 2012-07-20T07:20:41.987 回答
2

“window.open”将不起作用。这个命令总是只打开一个弹出窗口,它并不“总是”在其父级之上。

2个选项:

  1. 如果您只想让用户输入您可以使用的搜索字符串

    prompt("Please enter a search string:", "");
    
  2. 如果您有一个复杂的搜索表单,您必须为自己创建一个模式对话框。有提供此功能的框架(谷歌为“jQuery”)或者您自己创建它。应该不难,如果您需要帮助,请告诉我!

于 2012-07-20T07:33:24.567 回答