1
<html>
  <head>
    <title>Cordova Offline Example</title>

    <script type="text/javascript" charset="utf-8" src="cordova-1.9.0.js"></script>
    <script type="text/javascript" charset="utf-8">

    // Call onDeviceReady when Cordova is loaded.
    //
    // At this point, the document has loaded but cordova-1.9.0.js has not.
    // When Cordova is loaded and talking with the native device,
    // it will call the event `deviceready`.
    //

    function Network(){
        if(navigator.onLine)
            {
              alert('You are Online');
            }
        else
            {
              alert('You are Offline')
            }
     }
    </script>
  </head>
  <body >
  <input type="button" value="Check Network" onclick="Network()" />
  </body>
</html>

HTMLコードを使用してネットワーク接続を確認しようとしています。このコードをローカルマシンのクロムで実行すると機能しますが、なぜアンドロイドで機能しないのですか。

4

3 に答える 3

2

インターネット接続チェックの問題など、いくつかのタスクに使用する必要のある電話ギャップ固有のイベントがいくつかあります

これは、インターネット接続を確認できる例です。

<!DOCTYPE html>

navigator.network.connection.type例

<script type="text/javascript" charset="utf-8" src="phonegap-1.0.0.js"></script>
<script type="text/javascript" charset="utf-8">

// Wait for PhoneGap to load
// 
document.addEventListener("deviceready", onDeviceReady, false);

// PhoneGap is loaded and it is now safe to make calls PhoneGap methods
//
function onDeviceReady() {
    checkConnection();
}

function checkConnection() {
    var networkState = navigator.network.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.NONE]     = 'No network connection';

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

</script>

ダイアログボックスにネットワークの状態が報告されます。

詳細については、この 接続をご覧ください

于 2012-07-07T10:46:55.053 に答える
0

navigator.onLineブラウザーのオンライン ステータスを返すため、IE や Firefox のように、ステータスをオフライン作業に変更する機能を提供するブラウザーはほとんどありません。Chrome は、利用可能なネットワークに接続されている限り、onLine true を返します。

https://developer.mozilla.org/en/DOM/window.navigator.onLine

デバイスが実際にパブリック/プライベート ネットワークに接続されていることを確認するには、単純な AJAX 呼び出しを実行して、ターゲット マシンに到達できるかどうかを確認する必要があります。

必要なネットワークが実際に利用可能であることを確認し、それに基づいて必要なコードを実行するために、デバイスからプライベート VPN ネットワークに接続する必要があるアプリケーションの 1 つで上記のアプローチに従いました。

于 2012-07-07T11:39:44.990 に答える
0

//以下の行をコードの先頭に追加して、チェックします。

<!DOCTYPE HTML>
于 2012-07-07T10:44:48.807 に答える