Network Information API
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The Network Information API provides information about the system's connection in terms of general connection type (e.g., 'wifi', 'cellular', etc.). This can be used to select high definition content or low definition content based on the user's connection. The entire API consists of the addition of the NetworkInformation
interface and a single property to the Navigator
interface: Navigator.connection
.
Note: This feature is available in Web Workers
Examples
Detect connection changes
This example watches for changes to the user's connection.
var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection; var type = connection.effectiveType; function updateConnectionStatus() { console.log("Connection type changed from " + type + " to " + connection.effectiveType); type = connection.effectiveType; } connection.addEventListener('change', updateConnectionStatus);
Preload large resources
The connection object is useful for deciding whether to preload resources that take large amounts of bandwidth or memory. This example would be called soon after page load to check for a connection type where preloading a video may not be desirable. If a cellular connection is found, then the preloadVideo
flag is set to false
. For simplicity and clarity, this example only tests for one connection type. A real-world use case would likely use a switch statement or some other method to check all of the possible values of NetworkInformation.type
. Regardless of the type
value you can get an estimate of connection speed through the NetworkInformation.effectiveType
property.
let preloadVideo = true; var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection; if (connection) { if (connection.effectiveType === 'slow-2g') { preloadVideo = false; } }
Interfaces
NetworkInformation
-
Provides information about the connection a device is using to communicate with the network and provides a means for scripts to be notified if the connection type changes. The
NetworkInformation
interfaces cannot be instantiated. It is instead accessed through theNavigator
interface.
Specifications
Specification |
---|
Network Information API |
Browser compatibility
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
Network_Information_API |
61 |
79 |
31 |
No |
Yes |
No |
50 |
38 |
14
The Network API is enabled by default. Can be disabled using the
dom.netinfo.enabled preference. |
37 |
No |
3.0 |
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
Network_Information_API |
61 |
79 |
No |
No |
48 |
No |
50 |
38 |
31 |
45 |
No |
3.0 |
downlink |
61
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
79
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
No |
No |
48
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
No |
50
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
38
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
? |
45
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
No |
3.0
The value is never greater than 10 Mbps, as a non-standard anti-fingerprinting measure.
|
downlinkMax |
61
Only supported in Chrome OS
|
No |
No |
No |
No |
No |
50 |
38 |
No |
45 |
No |
3.0 |
effectiveType |
61 |
79 |
No |
No |
48 |
No |
50 |
38 |
Yes |
45 |
No |
3.0 |
onchange |
61 |
79 |
No |
No |
48 |
No |
50 |
38 |
No
On Firefox, the event handler property corresponding to the
change event is ontypechange . |
45 |
No |
3.0 |
ontypechange |
No |
No |
No |
No |
? |
No |
No |
38 |
31 |
? |
No |
3.0 |
rtt |
61
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
79
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
No |
No |
48
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
No |
50
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
38
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
No |
45
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
No |
3.0
The value is never greater than 3000 ms, as a non-standard anti-fingerprinting measure.
|
saveData |
65 |
79 |
No |
No |
Yes |
No |
65 |
65 |
? |
Yes |
No |
9.0 |
type |
61
Only supported in Chrome OS
|
No |
No |
No |
No |
No |
50 |
38 |
31 |
45 |
No |
3.0 |
worker_support |
61 |
79 |
No |
No |
48 |
No |
50 |
38 |
53 |
45 |
No |
3.0 |
BCD tables only load in the browser
Navigator.connection
BCD tables only load in the browser
See also
© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/Network_Information_API