如果要按下“F2”,我想打开新窗口。下面的代码在firefox中给了我newWindow is null
错误消息。如果我不使用弹出窗口阻止程序,它将起作用。在IE中也一样。即使启用了弹出式窗口拦截器,它也可以在chrome中运行。
使用jstree pre 1.0 stable
hotkeys: {
"f3" : function () {
url = "http://www.vse.cz";
var newWindow = window.open(url, '_blank');
newWindow.focus();
return false;
},
问题1:我可以使它适用于所有浏览器,以便用户在使用热键插件时不必更改其设置吗?
问题2: Using JavaScript instead of target to open new windows如何在Firefox中没有任何麻烦?那是因为它是一个链接而不使用热键插件吗?
我的理解是上一页的脚本不知何故
操纵发生的事情
用户单击链接时。它更改了点击的属性,因此
浏览器“不知道”这是新窗口,因此弹出窗口阻止程序是
绕过。
在我的情况下,我使用由其他东西触发的纯js函数,而不是由
用户点击。而且,“我的功能”不会更改任何html对象的属性。我认为这是有区别的。我不确定我是否
就在这儿。
最佳答案
不幸的是,您无法在按键上打开新窗口(除了禁用弹出窗口阻止程序外)。
IE,Firefox和Chrome中的弹出窗口阻止程序的工作方式(从较高级别)是由浏览器(在遇到window.open
调用时)在JavaScript调用堆栈中向上移动以确定当前函数是-还是被函数即事件处理程序。换句话说,它查找当前功能是否正在执行,因为用户执行了触发DOM事件的操作。
如果是这样,则允许弹出窗口;否则将被阻止。但是,哪些事件符合“弹出窗口允许”的问题因浏览器而异。 By default in Mozilla,仅change
,click
,dblclick
,mouseup
,reset
和submit
合格。 (我认为IE是类似的。)
作为其他任何事件类型的事件处理程序的函数(例如keydown
/ keyup
/ keypress
),不是才有资格获得特殊的弹出窗口允许处理,这意味着您的弹出窗口被阻止了,这就是为什么调用window.open
会返回null
。
但是,Chrome浏览器确实认为keydown
事件符合允许打开弹出窗口的条件,因此您的脚本可以在该浏览器中运行。
Here's a reduced example演示其工作原理。该演示:
spawn()
的函数,该函数调用window.open
打开一个弹出窗口。 spawn()
。由于该调用是从全局范围进行的,因此所有浏览器都将其阻止。它不是从事件处理程序中调用的。 window.onkeydown
,该函数调用spawn()
。如果您在Chrome中按任意键,则会打开弹出窗口,因为它允许keydown
处理程序弹出窗口。在IE和Firefox中,由于这些浏览器不允许来自键盘事件的弹出窗口,因此该弹出窗口将被阻止。 spawn()
的链接。当您单击链接时,所有浏览器都将允许弹出窗口,因为对window.open
的调用可以追溯到click
事件的事件处理程序。 如您现在所见,没有任何事情可以操纵事件属性或“欺骗”浏览器,以至于不知道存在新窗口。通过设计,允许通过链接单击打开弹出窗口的行为为。理论上讲,如果您单击了某些内容,则很可能希望查看弹出窗口中的内容。但是,当您从未执行任何操作(例如,全局范围)的地方调用
window.open
时,您可能对自动启动弹出窗口中的[ad]都不感兴趣。这样,弹出窗口阻止程序可以防止烦恼(自动启动广告),同时仍允许页面根据用户的请求打开弹出窗口。