cordova-plugin-network-information

Android Testsuite Chrome Testsuite iOS Testsuite Lint Test

此插件提供了一个旧版本的网络信息 API 的实现。它提供有关设备的蜂窝和 Wi-Fi 连接以及设备是否具有互联网连接的信息。

要了解如何使用该插件的一些想法,请查看此页面底部的示例或直接转到参考内容。

安装

cordova plugin add cordova-plugin-network-information

支持的平台

  • Android
  • 浏览器
  • iOS
  • Windows

连接

通过 navigator.connection 公开的 connection 对象提供有关设备的蜂窝和 Wi-Fi 连接的信息。

属性

  • connection.type

常量

  • Connection.UNKNOWN
  • Connection.ETHERNET
  • Connection.WIFI
  • Connection.CELL_2G
  • Connection.CELL_3G
  • Connection.CELL_4G
  • Connection.CELL
  • Connection.NONE

connection.type

此属性提供了一种快速确定设备网络连接状态和连接类型的方法。

快速示例

function checkConnection() {
    var networkState = navigator.connection.type;

    var states = {};
    states[Connection.UNKNOWN]  = 'Unknown connection';
    states[Connection.ETHERNET] = 'Ethernet connection';
    states[Connection.WIFI]     = 'WiFi connection';
    states[Connection.CELL_2G]  = 'Cell 2G connection';
    states[Connection.CELL_3G]  = 'Cell 3G connection';
    states[Connection.CELL_4G]  = 'Cell 4G connection';
    states[Connection.CELL]     = 'Cell generic connection';
    states[Connection.NONE]     = 'No network connection';

    alert('Connection type: ' + states[networkState]);
}

checkConnection();

iOS 特性

  • <iOS7 无法检测蜂窝网络连接的类型。
    • 对于所有蜂窝数据,navigator.connection.type 都设置为 Connection.CELL

Windows 特性

  • 在 Phone 8.1 模拟器中运行时,始终将 navigator.connection.type 检测为 Connection.ETHERNET

浏览器特性

  • 浏览器无法检测网络连接的类型。在线时,navigator.connection.type 始终设置为 Connection.UNKNOWN

与网络相关的事件

offline

当应用程序脱机且设备未连接到互联网时,会触发该事件。

document.addEventListener("offline", yourCallbackFunction, false);

详情

当先前连接的设备失去网络连接,导致应用程序无法再访问互联网时,会触发 offline 事件。 它依赖于与 Connection API 相同的信息,并在 connection.type 的值变为 NONE 时触发。

应用程序通常应使用 document.addEventListenerdeviceready 事件触发后附加事件侦听器。

快速示例

document.addEventListener("offline", onOffline, false);

function onOffline() {
    // Handle the offline event
}

特性

此插件无法在后台广播事件。请改用 navigator.connection.type恢复事件中检查连接状态。

iOS 特性

在初始启动期间,第一个脱机事件(如果适用)至少需要一秒钟才能触发。

online

当应用程序上线且设备连接到互联网时,会触发此事件。

document.addEventListener("online", yourCallbackFunction, false);

详情

当先前未连接的设备接收到网络连接以允许应用程序访问互联网时,会触发 online 事件。它依赖于与 Connection API 相同的信息,并在 connection.typeNONE 更改为任何其他值时触发。

应用程序通常应使用 document.addEventListenerdeviceready 事件触发后附加事件侦听器。

快速示例

document.addEventListener("online", onOnline, false);

function onOnline() {
    // Handle the online event
}

特性

此插件无法在后台广播事件。请改用 navigator.connection.type恢复事件中检查连接状态。

iOS 特性

在初始启动期间,第一个 online 事件(如果适用)至少需要一秒钟才能触发,在此之前,connection.typeUNKNOWN

示例:根据您的网络状态上传文件

本节中的代码示例显示了使用在线和离线事件以及您的网络连接状态更改应用程序行为的示例。

首先,创建一个新的 FileEntry 对象 (data.txt) 用于示例数据。从 deviceready 处理程序调用此函数。

注意 此代码示例需要 File 插件。

var dataFileEntry;

function createSomeData() {

    window.requestFileSystem(window.TEMPORARY, 5 * 1024 * 1024, function (fs) {

        console.log('file system open: ' + fs.name);
        // Creates a new file or returns an existing file.
        fs.root.getFile("data.txt", { create: true, exclusive: false }, function (fileEntry) {

          dataFileEntry = fileEntry;

        }, onErrorCreateFile);

    }, onErrorLoadFs);
}

接下来,在 deviceready 处理程序中为在线和离线事件添加侦听器。

document.addEventListener("offline", onOffline, false);
document.addEventListener("online", onOnline, false);

应用程序的 onOnline 函数处理在线事件。在事件处理程序中,检查当前的网络状态。在此应用程序中,将除了 Connection.NONE 之外的任何连接类型都视为良好。如果您有连接,则尝试上传文件。

function onOnline() {
    // Handle the online event
    var networkState = navigator.connection.type;

    if (networkState !== Connection.NONE) {
        if (dataFileEntry) {
            tryToUploadFile();
        }
    }
    display('Connection type: ' + networkState);
}

当在前面的代码中触发在线事件时,请调用应用程序的 tryToUploadFile 函数。

如果上传失败,则调用应用程序的 offlineWrite 函数将当前数据保存到某处。

注意 为简单起见,省略了文件读取和写入。有关文件处理的更多信息,请参阅 cordova-plugin-file 文档。

function tryToUploadFile() {
    // !! Assumes variable fileURL contains a valid URL to a text file on the device,
    var fileURL = getDataFileEntry().toURL();
    
    getFileBlobSomehow(fileURL, function(fileBlob) {
        var success = function (r) {
            console.log("Response = " + r.response);
            display("Uploaded. Response: " + r.response);
        };

        var fail = function (error) {
            console.log("An error has occurred: Code = " + error.code || error.status);
            offlineWrite("Failed to upload: some offline data");
        }

        var xhr = new XMLHttpRequest();

        xhr.onerror = fail;
        xhr.ontimeout = fail;
        xhr.onload = function() {
            // If the response code was successful...
            if (xhr.status >= 200 && xhr.status < 400) {
                success(xhr);
            }
            else {
                fail(xhr)
            }
        }

        // Make sure you add the domain of your server URL to the
        // Content-Security-Policy <meta> element in index.html.
        xhr.open("POST", encodeURI(SERVER));

        xhr.setRequestHeader("Content-Type", "text/plain");

        // The server request handler could read this header to
        // set the filename.
        xhr.setRequestHeader("X-Filename", fileURL.substr(fileURL.lastIndexOf("/") + 1));

        xhr.send(fileBlob);
    });
};

以下是 offlineWrite 函数的代码。

注意 此代码示例需要 File 插件。

function offlineWrite(offlineData) {
    // Create a FileWriter object for our FileEntry.
    dataFileEntry.createWriter(function (fileWriter) {

        fileWriter.onwriteend = function () {
            console.log("Successful file write...");
            display(offlineData);
        };

        fileWriter.onerror = function (e) {
            console.log("Failed file write: " + e.toString());
        };

        fileWriter.write(offlineData);
    });
}

如果发生脱机事件,只需执行类似通知用户的操作(对于此示例,只需记录它)。

function onOffline() {
    // Handle the offline event
    console.log("lost connection");
}