デバイスにインターネット接続がないときにポップアップを表示しようとしています。
次の例 は機能していますが、結果が「ネットワーク接続なし」の場合にのみアラートを表示したいと思います。
私はこれを試しました:
if (states[Connection.NONE]){
alert('Geen internet :(');
};
ただし、接続があるかどうかに関係なく、アラートボックスがポップアップするだけです。誰が私を助けられるか? :)
古風な質問ですが、これが私のやり方です-イベントを使用して、デバイスがオンラインかオフラインかを検出できます。デバイスがオフラインになるとすぐにポップアップが表示されるため、これはこの状況に最適です。
document.addEventListener("offline", function(){ alert("You're offline") }, false);
そして同じことをするために、しかしデバイスがインターネット接続を取り戻すとき?:
document.addEventListener("online", function(){ alert("You're online") }, false);
ここでイベントドキュメントを確認してください: http://docs.phonegap.com/en/1.8.1/cordova_events_events.md.html#offline
更新:
cordova 5の時点で、これらのイベントは cordova-plugin-network-information に移動されました。
もしあなたがそうするなら
if (states[Connection.NONE]){
alert('Geen internet :(');
};
これは起こります。
これを行う。
networkState = navigator.network.connection.type
alert(states[networkState]);
これがuで機能するかどうかを確認してください。
編集:比較するだけです:
if (networkState == Connection.NONE){
alert('no internet ');
};
他に何もしないために追加してください...
if (navigator.network.connection.type == Connection.NONE) {
alert('Geen internet :(');
}
else {
// nothing
};
これは、定数の真実性をテストしているためです。このタイプのテストは常にtrueを返します。使用したいものは次のとおりです。
if (navigator.network.connection.type == Connection.NONE]{
alert('Geen internet :(');
};
ここでcordova2.0.0の最新のドキュメントを確認してください: http://docs.phonegap.com/en/2.0.0/cordova_connection_connection.md.html#Connection
良い例があります。 Connection.NONEまたはConnection.UNKNOWNを確認する必要があります。どちらもインターネットがないことを意味します。それ以外の場合は、何らかのインターネット接続があることを意味します。
解決 :
<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>
ここでいくつかの答えをまとめているだけですが、オンライン/オフラインのイベントに応答するだけでなく、インターネット接続があるかどうかを最初から知っているものが欲しかったのです。状態の変化についてブロードキャストするAngularコントローラーでこれを使用していましたが、簡単にするためにこれらの部分を削除しました。
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
var _curStatus = false;
function toggleStatus(newVal) {
console.log('Setting internet connection state to: ' + newVal);
_curStatus = newVal;
// My angular $broadcast went here
}
var conType = navigator.network.connection.type;
toggleStatus((conType != Connection.NONE) && (conType != Connection.UNKNOWN));
document.addEventListener("online", function() {toggleStatus(true);}, false);
document.addEventListener("offline", function() {toggleStatus(false);}, false);
}
}
<script type="text/javascript" charset="utf-8">
// Wait for device API libraries to load
//
document.addEventListener("deviceready", onDeviceReady, false);
// device APIs are available
//
function onDeviceReady() {
checkConnection();
}
function checkConnection() {
var networkState = navigator.connection.type;
if(navigator.connection.type == Connection.NONE) {
alert("No network connection.Please turn it on");
}
}
</script>
Try the below code.
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';
if ((states[networkState]) == states[Connection.NONE])
{
alert("Please check your internet connectivity and try again");
}