首頁 web前端 js教程 透過JS判斷聯網類型和連線狀態的實現程式碼_javascript技巧

透過JS判斷聯網類型和連線狀態的實現程式碼_javascript技巧

May 16, 2016 pm 04:06 PM

中國的行動網路環境複雜,為了帶給使用者更好存取體驗,開發者希望能了解使用者目前的連網方式,然後給使用者一個符合目前網路環境的請求結果。

W3C的規範中給出了一個方法來獲得現在的網絡狀態navigator.connection;根據Working Draft 29 November 2012協議規範我們可以從接口中獲得bandwidth(帶寬,M/s)和metered兩個參數的值;也提供了一個監聽方法,來時刻監聽接入環境的變化。現實中我們發現很多瀏覽器並沒有回傳bandwidth值,而且遵守了Working Draft 07 June 2011的協定回傳給我們type(類型,wifi/2g/3g/4g)。

我們接下來就來看看各家的支援狀況

Android 2.3 Browser UC Dolphin QQ浏览器 Baidu Firefox Chrome Opera Mini Maxthon
Yes No* Yes Yes* Yes Yes(New) No No Yes

說明下在iPhone中任何瀏覽器都無法得到相關資訊。

透過上面的說明,我們發現還是可以透過這個參數來了解很大一部分用戶的聯網情況的,並且為他們提供更優質的體驗。
接下來我們重點說說各瀏覽器的回傳情況。

大部分瀏覽器會回傳一個int型的類型,其中的特例是QQ瀏覽器,傳回的就是型別名稱,對應關係如下

返回值 QQ返回值 类型
0 unknown UNKNOWN
1 ethernet ETHERNET
2 wifi WIFI
3 2g CELL_2G
4 3g CELL_3G
5 4g CELL_4G(中国现在也会出现这个值,是hspa )
? none NONE

接下去是一個更大的特例,這就是firefox,他使用了新版規範,所以返回的是bandwidth;不過很奇怪的是只要是wifi或3G他就返回20,如果是2G返回的就是0.1953125 ;每次都一樣不管現在網路狀態到底是多少。這個問題還會繼續跟進。

提供一個demo位址給大家:http://demo.jb51.net/js/2015/net.html
Demo中對不支援connection的瀏覽器直接返回了{type:0},這樣就很便利解決了某些瀏覽器不支援的問題;對於不支援又能上網的瀏覽器處理為「unknown」當然也是合乎情理的。

很多工程師覺得這個功能支援還不好,還是先不使用的好;但是我覺得只要錯誤能被處理,風險能被把控,為什麼不給那些先天優秀的客戶提供更友善的體驗呢。

今天同學說到讓後端判斷速度,這個可能有點難;不過確實可以透過每次的非同步請求去得到使用者大概的速度(載入的時間和檔案大小其實前端都能得到),然後在選擇性的提供某些服務,之後也準備往這個方向多思考下。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

前端熱敏紙小票打印遇到亂碼問題怎麼辦? 前端熱敏紙小票打印遇到亂碼問題怎麼辦? Apr 04, 2025 pm 02:42 PM

前端熱敏紙小票打印的常見問題與解決方案在前端開發中,小票打印是一個常見的需求。然而,很多開發者在實...

神秘的JavaScript:它的作用以及為什麼重要 神秘的JavaScript:它的作用以及為什麼重要 Apr 09, 2025 am 12:07 AM

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

誰得到更多的Python或JavaScript? 誰得到更多的Python或JavaScript? Apr 04, 2025 am 12:09 AM

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

如何使用JavaScript將具有相同ID的數組元素合併到一個對像中? 如何使用JavaScript將具有相同ID的數組元素合併到一個對像中? Apr 04, 2025 pm 05:09 PM

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

JavaScript難以學習嗎? JavaScript難以學習嗎? Apr 03, 2025 am 12:20 AM

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

如何實現視差滾動和元素動畫效果,像資生堂官網那樣?
或者:
怎樣才能像資生堂官網一樣,實現頁面滾動伴隨的動畫效果? 如何實現視差滾動和元素動畫效果,像資生堂官網那樣? 或者: 怎樣才能像資生堂官網一樣,實現頁面滾動伴隨的動畫效果? Apr 04, 2025 pm 05:36 PM

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

console.log輸出結果差異:兩次調用為何不同? console.log輸出結果差異:兩次調用為何不同? Apr 04, 2025 pm 05:12 PM

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...

JavaScript的演變:當前的趨勢和未來前景 JavaScript的演變:當前的趨勢和未來前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

See all articles