本文主要记录如何监听网络状态和网络速度。
获取当前网络状态:
navigator.onLine // true:在线 false:离线
监听事件:online(联网) 和 offline(断网)
window.addEventListener('online',function () {
console.log('online')
})
window.addEventListener('offline',function () {
console.log('offline')
})
获取当前网络信息
navigator.connection // 返回 NetworkInformation 包含网络速度等信息

监听网络变化
navigator.connection.addEventListener('change',()=>{
console.log(navigator.connection.effectiveType)
if (navigator.connection.effectiveType === '2g' || navigator.connection.effectiveType === 'slow-2g'){
alert('当前网络状态不佳')
}
})

navigator.connection在不同浏览器的兼容是不一样的
需要注意的是,即使浏览器支持navigator.connection属性,也不能保证所有设备和操作系统都支持该属性。因此,在使用navigator.connection属性之前,最好先检查其是否存在,以及是否为undefined。