活动选项卡时刷新页面

Refresh page when active tab

目前在我的页面中,我使用它每分钟刷新一次页面:

<head>
...
<meta http-equiv="refresh" content="60" />
...
</head>

相反,我想在用户按下选项卡时刷新页面。假设用户在网络浏览器中打开了多个选项卡。他在另一个选项卡上浏览了几分钟。当他然后按下我网站的选项卡时,我希望页面自动刷新,这样用户就不必自己检查页面上的任何更新。我怎样才能做到这一点?

你应该使用 js 和可见性 API:

在您的 html 页面中加入这个小脚本:

<script>
document.addEventListener("visibilitychange", function() {
   if (document.hidden){
       console.log("Browser tab is hidden")
   } else {
       console.log("Browser tab is visible")
       location.reload();
   }
});
</script>

改编自此处: Event for when user switches browser tabs