使用 jQuery/Javascript 防止任何形式的页面刷新

IT技术 javascript jquery refresh
2021-01-12 12:11:46

一旦用户在我的页面上,我不希望他刷新页面。

  1. 任何时候,用户点击F5或刷新顶部的按钮。他应该得到警报说

    您无法刷新页面。

  2. 此外,如果用户打开一个新选项卡并尝试访问上一个选项卡中的相同网址,他应该收到警报

    您不能在 2 个选项卡中打开同一页面

无论如何,我可以使用 JavaScript 或 jQuery 来做到这一点吗?第一点真的很重要。

6个回答

#1 可以通过window.onbeforeunload.

例如:

<script type="text/javascript">
    window.onbeforeunload = function() {
        return "Dude, are you sure you want to leave? Think of the kittens!";
    }
</script>

用户将收到消息提示,并提供留在页面上或继续前进的选项。这变得越来越普遍。如果您在键入帖子时尝试离开页面,Stack Overflow 会执行此操作。你不能完全阻止用户重新加载,但如果他们这样做,你可以让它听起来很可怕。

#2 或多或少是不可能的。即使您跟踪会话和用户登录,您仍然无法保证您正确检测到第二个选项卡。例如,也许我打开了一个窗口,然后将其关闭。现在我打开一个新窗口。即使我已经关闭了第一个选项卡,您也可能会将其检测为第二个选项卡。现在您的用户无法访问第一个窗口,因为他们关闭了它,并且他们无法访问第二个窗口,因为您拒绝了他们。

事实上,我银行的在线系统真的很努力地做#2,而且上面描述的情况一直在发生。我通常必须等到服务器端会话过期才能再次使用银行系统。

我知道这个问题很老,但是,如果他们真的想阻止多个会话,他们可以使用 WebSockets 吗?
2021-03-13 12:11:46
对我有用,尽管您应该使用 window.addEventListener(参见developer.mozilla.org/en-US/docs/Web/Events/beforeunload),以实现跨浏览器兼容性并防止库问题。
2021-03-17 12:11:46
请注意,onbeforeunload 事件在 Opera 浏览器版本中不可用。
2021-03-24 12:11:46
如果用户选择留在页面上,有没有办法做一些事情。
2021-03-26 12:11:46
@Sean - 是的......如果你真的想阻止多个会话。WebSocket 可以进行有状态的双向通信。当 WebSocket 连接时,客户端(可能)不会突然变成其他人,因此您应该能够为该用户分配一个令牌,并在套接字关闭后清除它。但是,它绕过了用户代理的预期行为,所以它可能是糟糕的用户体验。我能想到的情况很少有这样的事情是合适的(也许是一个在线游戏 - 以防止某人以两个37 级死亡爪登录......)。
2021-03-31 12:11:46

你不能阻止用户刷新,也不应该真的去尝试。你应该回到为什么你需要这个解决方案,这里的根本问题是什么?。从那里开始,找到解决问题的不同方法。也许您详细说明了为什么您认为需要这样做,这将有助于找到这样的解决方案。

打破基本的浏览器功能从来都不是一个好主意,超过 99.999999999% 的互联网工作并使用 F5 刷新,这是用户期望,你不应该打破。

@Siriris:没错。另外,我正在制作一个私人应用程序,即使他不在他的私人网络中,用户也应该能够使用它。所以我将所有内容都存储在浏览器存储中以供离线使用,但是如果他重新加载页面,整个应用程序就消失了。它可能不是很“平常”,但在这个现代 IT 世界中,它会变得越来越“平常”。
2021-03-16 12:11:46
我不确定你从哪里来。如果您的表单很脏,则 Internet 上的无数站点会阻止浏览器刷新,提醒您可能会丢失更改的事实。不知道为什么这是“破坏基本的浏览器功能”。
2021-03-17 12:11:46
@pankaj - 这应该在应用程序站点上修复,例如 cookie,以便用户跨选项卡共享会话。
2021-04-02 12:11:46
问题是,该页面是一个 siebel 应用程序。当用户在会话中并点击刷新时,会创建一个新会话,然后应用程序崩溃。所以我需要用户无法刷新。
2021-04-03 12:11:46
你不应该这样做,这不是一个答案。这个意见可能很有value,但只能作为工作解决方案的后记。
2021-04-05 12:11:46

尽管禁用 F5 键不是一个好主意,但您可以在 JQuery 中执行此操作,如下所示。

<script type="text/javascript">
function disableF5(e) { if ((e.which || e.keyCode) == 116 || (e.which || e.keyCode) == 82) e.preventDefault(); };

$(document).ready(function(){
     $(document).on("keydown", disableF5);
});
</script>

希望这会有所帮助!

OSX 怎么样,它是 CMD + R 吗?或者有一个按钮可以按下的移动设备?我不认为这是一个解决方案
2021-03-13 12:11:46

回到 CGI 的旧时代,我们有许多表单可以触发各种后端操作。例如对组的文本通知、打印作业、数据农业等。

如果用户在一个页面上说“请稍候......执行一些可能需要一些时间的巨大工作。”。他们更有可能点击刷新,这将是糟糕的!

为什么?因为它会触发更多缓慢的工作并最终使整个事情陷入困境。

解决方案?允许他们做他们的形式。当他们提交表单时... 开始你的工作,然后将他们引导到另一个页面,告诉他们等待。

中间的页面实际上保存了启动作业所需的表单数据。然而,WAIT 页面包含一个 javascript 历史销毁。因此,他们可以随心所欲地重新加载该等待页面,并且它永远不会触发原始作业在后台启动,因为该 WAIT 页面仅包含 WAIT 本身所需的表单数据。

希望这是有道理的。

历史记录销毁功能也阻止了他们点击返回然后刷新。

它非常无缝,并且在非营利组织倒闭之前一直很好地工作了很多年。

示例:FORM ENTRY - 收集他们的所有信息,并在提交时触发您的后端工作。

来自表单条目的响应 - 返回执行重定向到静态等待页面和/或 POST/GET 到另一个表单(等待页面)的 HTML。

等待页面 - 仅包含与等待页面相关的 FORM 数据以及用于销毁最近历史记录的 javascript。像 (-1 OR -2) 只销毁最近的页面,但仍然允许它们返回到原始的 FORM 条目页面。

一旦他们进入您的 WAIT 页面,他们就可以根据需要单击 REFRESH,并且它永远不会在后端生成原始的 FORM 作业。相反,您的 WAIT 页面应该包含一个 META 定时刷新本身,以便它可以始终检查他们的工作状态。当他们的工作完成后,他们会从等待页面重定向到您希望的任何位置。

如果他们手动刷新...他们只是在那里再添加一项对他们的工作状态的检查。

希望有帮助。祝你好运。

您没有因为这个惊人且内容丰富的答案而获得足够的赞誉。谢谢!!
2021-03-28 12:11:46

不,没有。

我很确定没有办法拦截来自 JS 的刷新按钮的点击,即使有,也可以关闭 JS。

您可能应该退出 X(防止刷新)并找到 Y 的不同解决方案(无论可能是什么)。

正如@Paweł Własiuk 在另一条评论中所指出的:“你不应该这样做,这不是一个答案。这个意见可能很有value,但只是作为一个有效解决方案的附言。”
2021-04-05 12:11:46