javascript - 需要关闭 fancybox 按钮上的当前窗口单击

标签 javascript jquery fancybox window.closed

我需要它进行年龄验证,当我点击 fancybox 的 under21 Age 按钮时 - 我的当前窗口应该关闭。

我的代码是这样的:

<div style="display:none;">
<div id="age-popup">
    <div style="margin: 0 auto;text-align: center;">
        <h2>Welcome!</h2>
        <h3>Please Verify Your Age to Enter.</h3>
        <input type="button" name="age" onclick="return overage();" value="21 & Over" />
        <input type="button" id="WarringMsg" name="WarringMsg" onclick="close_window()" value="Under 21" />
    </div><br>
    <p>Our product is not appropriates for individuals under 18 and window will be close automatically.</p>
</div>

function overage()
{
      user = "verifieduser";
      setCookie("username", user, 30);
     jQuery.fancybox.close();   
}
function close_window() {
   // window.open("about:blank","_self");
   // window.close();
     window.open('','_self');
     self.close();
}

window.close 在 Chrome 和 FF 中不起作用。

最佳答案

普通的javascript无法随意关闭窗口。这是不久前推出的一项安全功能,旨在阻止各种恶意利用和烦恼。

From the latest working spec for window.close():

如果满足以下所有条件,Window 对象上的 close() 方法应该关闭浏览上下文 A:

相应的浏览上下文 A 是脚本可关闭的。 现有脚本的浏览上下文与浏览上下文 A 相似。 允许现有脚本的浏览上下文导航浏览上下文 A。 如果浏览上下文是由脚本创建的辅助浏览上下文(而不是由用户的操作),或者如果它是 session 历史记录仅包含一个文档的浏览上下文,则该浏览上下文是可脚本关闭的。 这意味着,除了一个小异常(exception)之外,不允许 javascript 关闭不是由同一 javascript 打开的窗口。

Chrome 允许这种异常(exception)——它不适用于用户脚本——但 Firefox 不允许。 Firefox 的实现表明:

仅允许对使用 window.open 方法由脚本打开的窗口调用此方法。 如果您尝试从 Greasemonkey/Tampermonkey/用户脚本使用 window.close,您将得到: Firefox:错误消息“脚本可能无法关闭不是由脚本打开的窗口”。 Chrome:只是默默地失败。

长期解决方案:

解决这个问题的最佳方法是制作 Chrome 扩展程序和/或 Firefox 插件。这些可以可靠地关闭当前窗口。

但是,对于 Greasemonkey/Tampermonkey 脚本来说,window.close 带来的安全风险要小得多; Greasemonkey 和 Tampermonkey 可以在其 API 中合理地提供此功能(本质上是为您打包扩展工作)。 考虑提出功能请求。

黑客解决方法:

Chrome 目前容易受到“自重定向”漏洞的攻击。因此,这样的代码目前可以在 Tampermonkey 脚本中运行:

open(location, '_self').close(); 在我看来,这是一种有缺陷的行为,并且可能会被 Chrome 的 future 版本阻止,因此在使用此技巧时请记住这一点。

Firefox 可以抵御该漏洞。因此,唯一的 JavaScript 方法是削弱安全设置,一次一个浏览器。

您可以打开about:config并设置 allow_scripts_to_close_windows 设置为 true。

如果您的脚本供个人使用,请继续执行。如果您要求其他人打开该设置,他们会明智且合理地带着偏见拒绝。

Chrome 目前没有等效的设置。 这可能适用于某些浏览器: HTML:

<input type="button" name="Quit" id="Quit" value="Quit" onclick="return quitBox('quit');" />
JavaScript:

function quitBox(cmd)
{   
    if (cmd=='quit')
    {
        open(location, '_self').close();
    }   
    return false;   
}

试试这个测试页面:(现已在 Chrome 40 和 Firefox 35 中测试)

http://browserstrangeness.bitbucket.org/window_close_tester.htm

关于javascript - 需要关闭 fancybox 按钮上的当前窗口单击,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30483662/

相关文章:

javascript - Fancybox 样式不起作用

javascript - 当选中一定数量的复选框时运行 jQuery 函数

javascript - 可以让 javascript 对象返回值而不是 self 吗?

javascript - 正则表达式包装的字符串不显示值

jquery 根据标题在页面加载时隐藏图像

javascript - JS 中嵌套列表项的多维数组或 json 对象

javascript - 如何在Jquery中的click事件中调用函数?

jquery - 如何使用 jQuery 判断 CSS3 动画处于哪个阶段?

javascript - Fancybox iframe 不出现

javascript - 使花式框透明