6

ナビゲーターが状態をオンライン/オフラインに変更したかどうかをどのように検出できますか?

何かのようなもの:

var oldState = navigator.onLine; 
window.navigator.onlinechange = function(evnt,newState) { 
         alert('your changed from' + oldState + ' to' + newState + 'state');
}
4

3 に答える 3

5

ボディのクラスとこのコードの助けを借りて、あなたは見つけることができます

window.ononline = function() {
    alert('You are now online');
}

window.onoffline = function() {
    alert('You are now offline');
}
于 2016-04-14T08:31:43.510 に答える
3

このようなもの(すべてのブラウザーがこれらのイベントをサポートしているわけではありません。現在、IE8,9およびFF>3のみがこれらのイベントをサポートしています):

var el = document.body;
if (el.addEventListener) {
   el.addEventListener("online", function () {
     alert("online");}, true);
   el.addEventListener("offline", function () {
     alert("offline");}, true);
}
else if (el.attachEvent) {
   el.attachEvent("ononline", function () {
     alert("online");});
   el.attachEvent("onoffline", function () {
     alert("offline");});
}
else {
   el.ononline = function () {
     alert("online");};
   el.onoffline = function () {
     alert("offline");};
}

ブラウザのサポートはさまざまです。これを確認してください:http://help.dottoro.com/ljnasgpu.php

于 2011-08-11T21:42:18.217 に答える
3

よりクロスブラウザ互換にする必要がある場合は、navigator.onLineプロパティをポーリングする必要があります。

var status = document.getElementById('status')

setInterval(function () {
  status.innerHTML = navigator.onLine ? 'online' : 'offline';  
}, 250);

デモ: http: //html5demos.com/nav-online

于 2011-08-11T21:49:16.770 に答える