当我们尝试用JavaScipt测网速

npm包地址

https://www.npmjs.com/package/network-speed-test

Github地址

https://github.com/penghuwan/network-speed-test

事情是这样的,最近尝试写一个通过判断当前网速,从而在前端控制范围请求去分步请求一个大型文件的库。这个东东我现在一行代码都还没写,除了突然发现这个需求的思路有些不太实际之外,另一个原因是我突然问自己——

前端尼玛要怎么判断网速啊?? ? !

前端判断网速的原理总结

(注:下面求的网速单位默认为KB/S)

通过查阅相关资料,我发现思路主要是分为以下几种:

1.通过img加载或者发起Ajax请求计算网速

通过请求一个和服务端同域的文件,例如图片等,在前端开始请求和收到响应两个时间点分别通过Date.now标记start和end,因为Date.now得出的是1970年1月1日(UTC)到当前时间经过的毫秒数,所以我们通过end - start求出时间差(ms),然后通过计算:

文件大小(KB) * 1000 /( end -start )

就可以计算出网速了(KB/S)。

而请求文件又有两种方法:通过img加载或者AJAX加载:

  • 通过创建img对象,设置onload监听回调,然后指定src, 一旦指定src,图片资源就会加载,完成时onload回调就会调用,我们可以根据时机分别标记start和end。
  • 通过AJAX进行请求,即创建XHR对象,在onreadystatechange回调里,判断当readystate = 4时候加载完成,根据时机分别标记start和end。

2.window.navigator.connection.downlink 网速查询

我们还可以通过一些H5的先进API去实现,例如这里我们可以使用的是window.navigator.connection.downlink 去查询,但是正如你所知道的是,这类API都是一副德性,即老生常谈的兼容性问题,所以我们一般都是作为一种预备的手段,通过能力检测,能用就用它,不能用就通过别的方法。而且需要注意downlink的单位是mbps,转化成KB/S的公式是

navigator.connection.downlink * 1024 / 8

乘1024可以理解,为什么后面要除8呢?这是因为mbps里的b指的是bit(比特),KB/s里面的B指的是Byte(字节),1字节(b)=8比特(bit),所以需要除个8

3. 一般来说,通过请求文件测算网速,单次可能会有误差,所以我们可以请求多次并计算均值。

前端判断网速的方法及其优缺点

  • img加载测速:借助img对象加载测算网速。优点:没有跨域带来的问题。缺点:(1)要自己测文件大小并提供参数fileSize,(2)文件必须为图片 (3)文件大小不能灵活控制
  • Ajax测速: 通过Ajax测算网速。 优点: (1)不用提供文件大小参数,因为可以从response首部获得(2)测试的文件不一定要是图片,且数据量能灵活控制。缺点:跨域问题
  • downlink测速: 通过navigator.connection.downlink读取网速。优点:不需要任何参数。缺点:1.兼容性很有问题,2.带宽查询不是实时的,具有分钟级别的时间间隔
  • 综合实现:先尝试采用downlink测速,否则多次AJAX测速并求平均值

img加载测速

function getSpeedWithImg(imgUrl, fileSize) {
    return new Promise((resolve, reject) => {
        let start = null;
        let end = null;
        let img = document.createElement(‘img‘);
        start = new Date().getTime();
        img.onload = function (e) {
            end = new Date().getTime();
            const speed = fileSize * 1000 / (end - start)
            resolve(speed);
        }
        img.src = imgUrl;
    }).catch(err => { throw err });
}

Ajax测速

function getSpeedWithAjax(url) {
    return new Promise((resolve, reject) => {
        let start = null;
        let end = null;
        start = new Date().getTime();
        const xhr = new XMLHttpRequest();
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4) {
                end = new Date().getTime();
                const size = xhr.getResponseHeader(‘Content-Length‘) / 1024;
                const speed = size * 1000 / (end - start)
                resolve(speed);
            }
        }
        xhr.open(‘GET‘, url);
        xhr.send();
    }).catch(err => { throw err });
}

downlink测速

function getSpeedWithDnlink() {
    // downlink测算网速
    const connection = window.navigator.connection;
    if (connection && connection.downlink) {
        return connection.downlink * 1024 / 8;
    }
}

综合测速

function getNetSpeed(url, times) {
    // downlink测算网速
    const connection = window.navigator.connection;
    if (connection && connection.downlink) {
        return connection.downlink * 1024 / 8;
    }
    // 多次测速求平均值
    const arr = [];
    for (let i = 0; i < times; i++) {
        arr.push(getSpeedWithAjax(url));
    }
    return Promise.all(arr).then(speeds => {
        let sum = 0;
        speeds.forEach(speed => {
            sum += speed;
        });
        return sum / times;
    })
}

以上代码我发了一个npm包,可以通过下载

npm i network-speed-test

使用方式

import * from ‘network-speed-test‘;
getSpeedWithImg("https://s2.ax1x.com/2019/08/13/mPJ2iq.jpg", 8.97).then(
    speed => {
        console.log(speed);
    }
)

getSpeedWithAjax(‘./speed.jpg‘).then(speed => {
    console.log(speed);
});

getNetSpeed(‘./speed.jpg‘, 3).then(speed => {
    console.log(speed);
});

getSpeedWithDnlink();

Github地址

https://github.com/penghuwan/network-speed-test

参考文章

https://juejin.im/post/5b4de6b7e51d45190d55340b

知乎账号

https://www.zhihu.com/people/peng-hu-wan-56/activities

原文地址:https://www.cnblogs.com/penghuwan/p/11366446.html

时间: 2024-08-28 04:56:47

当我们尝试用JavaScipt测网速的相关文章

linux测网速

下载测网速的python脚本进行测试:  wget https://raw.githubusercontent.com/sivel/speedtest-cli/master/speedtest.py chmod a+x speedtest.py ./speedtest.py

Linux 测网速

Linux 测网速: sar -n DEV 1 100 1代表一秒统计并显示一次 100代表统计一百次 使用ntop等工具,就更方便简单了,不过这个更灵活 P.S. sar在sysstat包 其他测试相关工具:http://blog.chinaunix.net/uid-20648944-id-2943611.html

Linux下如何测网速

Linux下测网速可以使用speedtest的命令,它是由Python语言编写,适用于Python2.4-Python3.4等版本.具体操作如下: 1.下载这个文件 wget https://raw.githubusercontent.com/sivel/speedtest-cli/master/speedtest.py (注:以前的是speedtest-cil,本文以centos7为例) 2.修改文件名,增加执行权限,移动到默认路径 mv speedtest.py speedtest chmo

ajax测网速

ajax测下载速度 前台 <%@ page contentType="text/html;charset=UTF-8" language="java"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head&

[Java]知乎下巴第1集:爬虫世界百度不仅仅可以拿来测网速

上一集中我们说到需要用Java来制作一个知乎爬虫,那么这一次,我们就来研究一下如何使用代码获取到网页的内容. 首先,没有HTML和CSS和JS和AJAX经验的建议先去W3C(点我点我)小小的了解一下. 说到HTML,这里就涉及到一个GET访问和POST访问的问题. 如果对这个方面缺乏了解可以阅读W3C的这篇:<GET对比POST>. 啊哈,在此不再赘述. 然后咧,接下来我们需要用Java来爬取一个网页的内容. 这时候,我们的百度就要派上用场了. 没错,他不再是那个默默无闻的网速测试器了,他即将

ubuntu 测网速

sudo apt install speedtest-cli 就是如此简单,安装这个之后.直接运行 speedtest-cli 原文地址:https://www.cnblogs.com/zdj8023/p/11600709.html

js 测试服务器网速

网站的加载速度对于一个网站来说非常重要,自己用着来自不同厂商的服务器,对比优劣,所给磁盘.内存空间等等感觉都够用不是事,主要响应速度有比较大的差异,直觉看比较麻烦,于是写了个简单的页面直接测试加载速度. head部分写入以下内容,记下开始时刻: <script> var start = new Date().getTime(); </script> 然后往body里添加一张图片,记下图片大小(your-img-size). 最后在</body>前插入一段js: <

双网卡实现网速叠加

之前看过网上的各种双网卡网速叠加的帖子,无非就是使用NIC Express软件,或者修改注册表的方式,但是NIC express这款软件貌似在win7下已经不能使用,而修改注册表既有风险又很复杂,不适合新手.接下来我将用最简洁的语言来讲述一下我是如何使用最简单的步骤实现网速叠加的. 首先要有两张网卡,我这里采用的是一张有线网卡和一张无线网卡,型号忽略,因为无论哪种都可以,不挑型号. 先说说我的网络环境吧.两张网卡均获取到115.24.169.x的IP地址,其中115.24.169.10是有线网卡

linux网速测试

1.这里使用的是root权限.centos7系统 2.运行wget https://github.com/sivel/speedtest-cli/archive/master.zip  #下载测速文件到当前目录 3.mkdir cesu   #新建测速文件夹 4.unzip master.zip -d cesu  #把master.zip解压到测速文件夹,提示没有安装unzip的话需要yum install unzip 5.mv speedtest_cli.py /usr/bin   #需要把解