我有一个选择框,调用window.open(url)当一个项目被选中。默认情况下,Firefox将在新选项卡中打开页面。但是,我希望页面在一个新的窗口中打开,而不是一个新的选项卡。

我怎样才能做到呢?


当前回答

我也有同样的问题,但我找到了一个相对简单的解决方法。

在JavaScript中,我检查了window。揭幕战! =零;来确定窗口是否弹出。如果你正在使用一些类似的检测代码来确定你的网站正在呈现的窗口是否是一个弹出窗口,你可以很容易地“关闭”它,当你想要打开一个“新”窗口使用新窗口JavaScript。

只要把它放在你的页面的顶部,你想永远是一个“新”窗口。

<script type="text/javascript">
    window.opener=null;
</script>

我在我的网站的登录页面上使用这个,所以如果用户使用弹出窗口导航到我的网站,他们就不会弹出窗口。

您甚至可以创建一个简单的重定向页面来执行此操作,然后移动到您提供的URL。类似的,

父页上的JavaScript:

window.open("MyRedirect.html?URL="+URL, "_blank");

然后通过javascript,你可以得到URL并重定向到它。

重定向页面上的JavaScript:

 <script type="text/javascript">
        window.opener=null;

    function getSearchParameters() {
          var prmstr = window.location.search.substr(1);
          return prmstr != null && prmstr != "" ? transformToAssocArray(prmstr) : {};
    }

    function transformToAssocArray( prmstr ) {
        var params = {};
        var prmarr = prmstr.split("&");
        for ( var i = 0; i < prmarr.length; i++) {
            var tmparr = prmarr[i].split("=");
            params[tmparr[0]] = tmparr[1];
        }
        return params;
    }

    var params = getSearchParameters();
    window.location = params.URL;
    </script>

其他回答

你不需要使用height,只要确保你使用_blank,没有它,它会在一个新选项卡中打开。

对于空窗口:

window.open('', '_blank', 'toolbar=0,location=0,menubar=0');

对于特定的URL:

window.open('http://www.google.com', '_blank', 'toolbar=0,location=0,menubar=0');

对我来说,解决办法就是

"location=0"

在第三个参数中。在最新的FF/Chrome和旧版本的IE11上测试

我使用的完整方法调用如下(因为我喜欢使用可变宽度):

window.open(url, "window" + id, 'toolbar=0,location=0,scrollbars=1,statusbar=1,menubar=0,resizable=1,width=' + width + ',height=800,left=100,top=50');

有趣的是,我发现如果您为window的第三个属性传递一个空字符串(而不是空字符串或属性列表)。打开,它将在Chrome, Firefox和IE的新选项卡中打开。如果缺席,行为就不同了。

这是我的新号召:

 window.open(url, windowName, '');

我认为这不是html目标属性问题,但你在“选项”菜单下的“选项卡”选项卡中选中了“在新选项卡中打开nw窗口”选项。请检查并重试。

为打开调用指定窗口“features”:

window.open(url, windowName, "height=200,width=200");

当您指定宽度/高度时,它将在一个新窗口中打开,而不是一个选项卡。

请参阅https://developer.mozilla.org/en-US/docs/Web/API/Window.open#Position_and_size_features了解所有可能的功能。