日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

如何用JavaScipt測網速

瀏覽:35日期:2023-06-04 08:00:43
前言

事情是這樣的,最近嘗試寫一個通過判斷當前網速,從而在前端控制范圍請求去分步請求一個大型文件的庫。這個東東我現在一行代碼都還沒寫,除了突然發現這個需求的思路有些不太實際之外,另一個原因是我突然問自己——前端要怎么判斷網速啊?? ? !

前端判斷網速的原理總結

(注:下面求的網速單位默認為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();npm包地址

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

Github地址

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

以上就是如何用JavaScipt測網速的詳細內容,更多關于用JavaScipt測網速的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品视频一区二区三区综合| 亚洲aa在线| 亚洲欧美久久| 精品一区欧美| 日韩亚洲国产欧美| 日韩精选在线| 日韩国产欧美在线播放| 欧美精品激情| 日韩av影院| 国产一区二区三区不卡av| av免费不卡国产观看| 精品国产亚洲一区二区三区大结局| 国产精品巨作av| 免费福利视频一区二区三区| 久久高清免费| 黄色免费成人| 欧美69视频| 国产高清久久| 亚洲一区日本| 三级久久三级久久久| 国产情侣久久| 久久久久亚洲精品中文字幕| 国内在线观看一区二区三区| 国产成人77亚洲精品www| 夜鲁夜鲁夜鲁视频在线播放| 亚洲91视频| 亚洲一区二区三区久久久| 精品中国亚洲| 国产一区二区三区精品在线观看| 色在线视频观看| 1024精品久久久久久久久| 日韩在线一区二区| 精品欠久久久中文字幕加勒比| 国内自拍视频一区二区三区| 国产精品久久久久蜜臀| 私拍精品福利视频在线一区| 婷婷亚洲五月色综合| 亚洲欧美日本日韩| 欧美天堂一区| 不卡在线一区| 亚洲精品欧美| 精品一区二区三区中文字幕视频| 日韩专区精品| 老牛影视一区二区三区| 日韩精品社区| 福利一区二区三区视频在线观看| 伊人久久大香线蕉av不卡| 日韩久久99| 久久69成人| 欧美日韩国产免费观看视频| 91国内精品| 日韩深夜视频| 亚洲乱码久久| 成人午夜网址| 亚洲一区网站| 国产一区二区三区国产精品| 夜夜嗨一区二区三区| 国产欧美久久一区二区三区| 久久久久一区| 日韩av不卡在线观看| 日韩一区二区中文| 亚洲精品第一| 久久久男人天堂| 日韩一区精品视频| 精品一区视频| 在线一区二区三区视频| 精品视频国内| 久久亚洲美女| 精品欧美一区二区三区在线观看| 亚洲69av| www在线观看黄色| 亚洲精品伊人| 99精品综合| 久久只有精品| 久久99蜜桃| 在线观看免费一区二区| 国产欧美日韩在线一区二区 | 亚洲乱码久久| 999久久久国产精品| 国产美女亚洲精品7777| japanese国产精品| 精品一区电影| 日本不卡一二三区黄网| 国内精品99| 久久毛片亚洲| 97久久超碰| 香蕉久久久久久久av网站| av资源中文在线| 久久成人av| 日韩一区精品| 999在线观看精品免费不卡网站| 麻豆精品视频在线观看免费| 免费成人在线观看| 私拍精品福利视频在线一区| 麻豆成人91精品二区三区| 久久亚洲一区| 亚洲精品成人| 久久天堂成人| 国产不卡人人| 日本久久精品| 中文一区一区三区高中清不卡免费| 免费看日韩精品| 久久精品123| 水蜜桃久久夜色精品一区| 欧美私人啪啪vps| 最新亚洲国产| 午夜在线一区| 91久久国产| 久久久久99| 久久久久国产精品一区三寸| 国产66精品| 精品免费视频| 精品国产成人| 精品国产亚洲一区二区三区| 国产区精品区| 国产精品夜夜夜| 日本午夜精品久久久久| 日本不卡视频在线| 日本a级不卡| 日本不卡视频在线| 日韩精品高清不卡| 日韩区欧美区| 日韩av中文在线观看| 日本亚洲不卡| 日韩精品一级| 日韩福利在线观看| 日韩欧美中文字幕在线视频| 天海翼精品一区二区三区| 日韩有码av| 国产精品一区毛片| 国产剧情在线观看一区| 亚洲精品免费观看| 日韩有码av| 国产日韩一区二区三免费高清| 国产亚洲一区| 久久字幕精品一区| av在线最新| 激情综合激情| 亚洲一区免费| 日本在线不卡视频| 亚洲免费资源| 欧美影院精品| 国产精品115| 国产一区二区三区四区| 日韩在线免费| 欧美99久久| 中文一区一区三区免费在线观| 日韩精品一区二区三区av| 国产精品久久免费视频| 国产一区二区三区探花| 久久天堂精品| 视频一区欧美精品| 欧美视频久久| 国产不卡一区| 国产专区一区| 伊人久久大香伊蕉在人线观看热v| 日韩精品免费观看视频| 久久爱www成人| 久久精品电影| 亚洲a级精品| 麻豆免费精品视频| 桃色一区二区| 国产精品毛片一区二区三区| 亚洲精品日韩久久| 国产精品99久久精品| 蜜臀久久99精品久久一区二区 | 蜜臀久久久99精品久久久久久| 日韩av影院| 日韩一区二区中文| 99国产一区| 国产日韩在线观看视频| 日本精品影院| 亚洲精品第一| 91一区二区三区四区| 亚洲自啪免费| 国产精品美女午夜爽爽| sm久久捆绑调教精品一区| 水野朝阳av一区二区三区| 国产精品任我爽爆在线播放| 日本久久成人网| 日韩精品免费观看视频| 日韩欧美在线中字| 亚洲a级精品| 亚洲播播91| 综合亚洲色图| 综合日韩av| 日日夜夜免费精品| 蜜桃av.网站在线观看| 色8久久久久| 国产专区一区| 国产剧情在线观看一区| 欧美精品激情| 国模大尺度视频一区二区| 亚洲少妇诱惑| 精品久久国产一区| 日韩在线播放一区二区| 高清av不卡| 亚洲精品影视| 久久九九99| 日韩1区2区日韩1区2区|