激活选项卡时刷新页面

问题描述

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

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

相反,当用户按下选项卡时,我想刷新页面。假设用户在Web浏览器中打开了多个标签。然后他花了几分钟在另一个选项卡上浏览。然后,当他按下我网站的选项卡时,我希望页面自动刷新,因此用户不必亲自检查页面上的任何更新。我该怎么做?

解决方法

您应该使用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