用JavaScript检测用户是否在线

开发 前端
我们可以利用navigator.onLine API来检测连接状态,它返回一个布尔值来表示用户是否在线。这种方式,我们不知道加载后网络状态是否发生变化,这并不理想。

有时候,我们需要知道当前网络的状态来做一些事情,以提升用户体验,这节课,我们来看一下,如何使用 JavaScript 来检测用户是否在线。

检测连接状态

我们可以利用navigator.onLine API来检测连接状态,它返回一个布尔值来表示用户是否在线。

注意:请注意各浏览器的实现方式不同,因此结果可能不同。

window.addEventListener('load', () => {
const status = navigator.onLine;
});

这种方式,我们不知道加载后网络状态是否发生变化,这并不理想。

我们可以订阅 offline​ 和 online 

window.addEventListener('offline', (e) => {
console.log('offline');
});

window.addEventListener('online', (e) => {
console.log('online');
});

事例

我们通过一个背景色的变化来演示当前的网络状态:

<div class="status">
<div class="offline-msg">You're offline 😢</div>
<div class="online-msg">You're connected 🔗</div>
</div>

对应的 css:

.status {
background: #efefef;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
div {
padding: 1rem 2rem;
font-size: 3rem;
border-radius: 1rem;
color: white;
font-family: Roboto, 'Helvetica Neue', Arial, sans-serif;
}
.online-msg {
background: green;
display: block;
}
.offline-msg {
background: red;
display: none;
}
}

默认情况下,显示在线信息。然后我们添加一个条件,如果状态元素有一个 offline 类,我们就切换这两个div。

.status {
&.offline {
.online-msg {
display: none;
}
.offline-msg {
display: block;
}
}
}

那么,我们如何根据网络状态来切换呢:

const status = document.querySelector('.status');
window.addEventListener('load', () => {
const handleNetworkChange = () => {
if (navigator.onLine) {
status.classList.remove('offline');
} else {
status.classList.add('offline');
}
};

window.addEventListener('online', handleNetworkChange);
window.addEventListener('offline', handleNetworkChange);
});

代码很简单,这里就不过多的介绍了。

图片

事例地址:https://codepen.io/rebelchris/pen/PoaQjqr

原文:https://dev.to/dailydevtips1/detecting-if-the-user-is-online-with-javascript-58ne

责任编辑:武晓燕 来源: 大迁世界
相关推荐

2013-06-09 14:12:42

监控

2021-03-18 18:07:57

JavaScript开发代码

2011-12-05 15:21:58

Knockout

2011-11-04 12:00:38

2010-06-18 13:36:49

SQL Server查

2021-04-29 00:08:21

JavaScript 检测文件

2010-08-26 10:41:07

2021-05-08 00:00:27

JavaScript ZIP文件

2021-01-28 18:06:49

JavaScriptCookieWeb

2021-03-27 11:02:04

JavaScript队列编程语言

2010-06-11 16:04:34

Windows 7驱动

2021-12-01 06:42:51

BruteLoops身份验证密码

2011-03-03 09:02:29

JavaScriptPHPAndroid

2009-06-05 11:11:11

2024-04-28 09:12:16

CSS文本是否溢出前端

2009-04-28 00:44:03

2020-10-15 12:24:00

JavaScript开发 教程

2011-03-03 12:27:34

2009-05-06 09:19:53

Silverlight检测微软

2015-04-16 15:14:54

点赞
收藏

51CTO技术栈公众号