我们的应用有时候需要知道用户的网络连接是否在线?比如根据网络是否正常访问,页面渲染不同的内容,或提示用户的操作等。
我们可以利用navigator.onLineapi 来检测连接状态。这将返回一个布尔值来指示用户是否在线。
注意:请注意各浏览器的实现方式不同,因此结果可能不同。
window.addEventListener('load', () => {
const status = navigator.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(scss)
.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
在某些情况下,浏览器可能会错误地“认为”它已连接,例如,如果连接到没有连接到 Internet 的网络。如果状态为“离线”则没有连接,但“在线”并不一定意味着存在连接。
由于这个API太不稳定的情况,我们还可以通过获取网络资源来判断,比如:插入一个网络图片,等同于发起请求:
let img = new Image();
img.src = './text.png?t='+Date.parse(new Date());
img.onload = function() {
alert('有网');
};
img.onerror = function() {
alert('没网');
};
或者通过ajax请求判断有没有网,如果ajax请求写的都是对的,那么请求成功既有网,请求失败既没网。
伴随着互联网技术的发展,现如今企业或品牌为了更好的进行宣传都会建设高质量的网站。而在网络建设过程中,要考量用户的喜好,只有做好这方面的工作才能够吸引到更多的用户。下面就跟随小编一起去学习一下网站建设应该做好的事
用户获取是确定网站成功的核心指标,没有活跃的用户会花费大量资金投入,在获得用户之后,网参与和保留是两个指标,可真实地洞察网站的成功,较低的网站参与度和保留率是导致网站失败的一个因素,而高度参与和保留则相反
在网站设计中,网站参与可以网站成功的一个指标,衡量优化效果内容互动指标很重要,会显示内容策略如何与用户保持一致,客户参与度与整体盈利能力相关,以下是一些常见的用户参与指标。
在浏览器里进行用户追踪会引发关于隐私和数据保护一次又一次的讨论。类似 Google 分析之类的工具几乎可以抓到所有需要的内容,包括来源,语言,设备,停留时间等等。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!