如何在 JavaScript 中打开新标签而不切换到新标签?

Posted

技术标签:

【中文标题】如何在 JavaScript 中打开新标签而不切换到新标签?【英文标题】:How to open new tab in JavaScript without switching to the new tab? 【发布时间】:2011-12-16 23:26:31 【问题描述】:

如何在不切换到新标签的情况下使用 javascript 打开新标签? 例如,当用户单击链接时,将打开一个新选项卡,但用户应停留在当前选项卡上。

【问题讨论】:

【参考方案1】:

很遗憾,您目前无法做到这一点 - 但您可以接近。您可以打开一个新的窗口,如果您在没有指定任何窗口尺寸或窗口功能的情况下这样做,大多数现代浏览器将打开一个新选项卡(取决于用户的偏好,但随后,您想要无论如何做用户喜欢的事情,对吧?)。所以只要window.open(url)window.open(url, name) 如果你打算用这个名字来做某事。请务必在直接响应用户启动的事件时执行此操作,否则浏览器的弹出窗口阻止程序可能会...阻止弹出窗口。 :-)

Live example

关于保持对窗口的关注...祝你好运。您可以在window.open(...) 之后调用window.focus(),但根据我的经验,它通常不起作用。

把它扔在那里:如果你让用户与一个真正的链接与一个 URL 交互的东西,用户可以决定是否在新标签、新窗口等中打开它,并且是否给它焦点(如果他们足够复杂,可以知道 Shift+Click 和 Ctrl+Shift+Click,或者右键菜单)。

【讨论】:

请注意,在 IE 中,这会在新窗口中打开,而不是在新选项卡中打开。 @josh3736:这取决于您使用的 IE 版本,以及在较新版本中,您的设置是什么。 忘记了我在 IE9 中更改了该设置。具体来说,window.open() 会在 IE 中创建一个新选项卡,除非选项 > 选项卡设置 > “让 IE 决定应如何打开弹出窗口”。【参考方案2】:

这是用户特定的设置,您无法从 JS 更改此行为。

【讨论】:

【参考方案3】:

网络浏览器会自动聚焦在新标签上,但您可以将焦点调回:

function openWindow( url )

  window.open(url, '_blank');
  window.focus();


<a href="http://www.example.com/" onclick="javascript:openWindow(this.href);return false;">Click Me</a>

【讨论】:

回复focus:根据我的经验,没有。无论如何都不用 Chrome (jsbin.com/aboluk/2) - 但尝试它们并没有太大的危害。 @josh3736:这很有趣。我还在 14 岁(在 Linux 上),但事实并非如此。所以基本上:你不能依赖它。 :) @T.J.Crowder:适用于 Chrome 14 Windows 和 Chrome 15 Ubuntu。 (也许您的设置中发生了一些奇怪的事情?)无论如何,它不适用于任何版本的 Firefox 或 Opera。 @T.J. Crowder 在 Ubuntu 上使用 Chrome 14 为我工作。 @Josh:......并且在 Ubuntu 11.10 上的 Chrome 15 中工作(根据我之前的评论,它应该是 Ubuntu 10.04 LTS 上的 Chrome 14)。【参考方案4】:

很遗憾,您无法在所有浏览器中执行此操作,但如果您实现了浏览器的扩展程序,则可以在 Chrome 中执行此操作。 如何通过 javascript 操作 Chrome 中的标签页:

http://code.google.com/chrome/extensions/tabs.html

chrome.tabs.create(object createProperties, function callback)
    Creates a new tab. Note: This function can be used without requesting the 'tabs' permission in the manifest.
Parameters
    **createProperties** ( object )
    **windowId** ( optional integer )
       The window to create the new tab in. Defaults to the current window.
    **index** ( optional integer )
       The position the tab should take in the window. The provided value will be clamped to between zero and the number of tabs in the window.
    **url** ( optional string )
       The URL to navigate the tab to initially. Fully-qualified URLs must include a scheme (i.e.    'http://www.google.com', not 'www.google.com'). Relative URLs will be relative to the current page within the extension. Defaults to the New Tab Page.
    **selected** ( optional boolean )
       Whether the tab should become the selected tab in the window. Defaults to true
    pinned ( optional boolean )
       Whether the tab should be pinned. Defaults to false
    **callback** ( optional function )

【讨论】:

【参考方案5】:
(function(a) 
    document.body.appendChild(a);
    a.setAttribute('href', location.href);
    a.dispatchEvent((function(e) 
        e.initMouseEvent("click", true, true, window, 0, 0, 0, 0, 0, 
                         true, false, false, false, 0, null);
        return e
    (document.createEvent('MouseEvents'))))
(document.createElement('a')))

【讨论】:

这适用于哪个浏览器?【参考方案6】:

帖子很旧,但没有任何 100% 正确答案。

适用于所有浏览器的解决方案:

您可以通过以下方式打开新标签页到相同域 URL:

window.open("newurl.php", "_blank");

对于跨域的新标签,您必须创建一个简单的本地脚本,如下所示:

在新文件“redirect.php”中,您传递一个参数(目标新标签网址),如下所示

<?php
   $newURL=$_GET['u'];
   header('Location: '.$newURL);
؟>

您可以使用任何目标网址创建一个新选项卡:

window.open("redirect.php?u=http://www.google.com", "_blank");

:)

这是我在我的网站上的解决方案。并与任何

【讨论】:

焦点仍在新标签上。请正确提问。 我认为这不能正确回答问题,并且还可能导致进一步的一些问题。 owasp.org/www-project-web-security-testing-guide/v41/…【参考方案7】:

对我来说,使用

window.open("https://***.com");

完美运行。这取决于您使用的浏览器、操作系统以及您的个人偏好。

Chrome、Internet Explorer 和 Firefox 都打开了一个新标签页。抱歉,如果这对您不起作用。

(才发现这是个老帖子)

【讨论】:

【参考方案8】:
 var isMobile = false;
        if (
          /(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|ipad|iris|kindle|Android|Silk|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test(
            navigator.userAgent
          ) ||
          /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(
            navigator.userAgent.substr(0, 4)
          )
        ) 
          isMobile = true;
        


    if (isMobile) 
    window.location.assign(url);
     else 
window.open(url);


【讨论】:

【参考方案9】:

在 Mac 中:Cmd+click 和在 Windows 中:ctrl+click 将在后台打开新标签。也许这是用户培训的问题,而不是需要以编程方式解决的问题?

来源: https://support.google.com/chrome/answer/157179?co=GENIE.Platform%3DDesktop&hl=en#zippy=%2Ctab-and-window-shortcuts%2Cmouse-shortcuts

【讨论】:

以上是关于如何在 JavaScript 中打开新标签而不切换到新标签?的主要内容,如果未能解决你的问题,请参考以下文章

使用 JavaScript 打开链接新窗口(不是选项卡)而不输入两次 URL? [复制]

在不同的新标签中打开两个链接,而不是在同一个

如何使用javascript和jquery中的<a>标签在新标签中打开链接[重复]

如何在javascript中捕获新标签事件中的打开链接?

如何在浏览器的新标签页显示新的内容?

如何使用javascript打开新标签中的数组链接?