phonegap Jquery在请求前检查数据连接

phonegap Jquery在请求前检查数据连接,jquery,Jquery,我有jquery代码,用于每30秒向服务器发送当前坐标。 它在具有良好数据覆盖信号的区域工作良好。但是,当信号不稳定时(数据覆盖率可用且反复消失),它会崩溃。几次之后,应用程序在没有任何警告的情况下在try…catch部分崩溃 我需要检查数据覆盖率是否可用,然后不断向服务器发送坐标,否则只需继续检查,直到数据覆盖率可用为止 这是我的密码: <!DOCTYPE html> <html> <head> <script type="te

我有jquery代码,用于每30秒向服务器发送当前坐标。 它在具有良好数据覆盖信号的区域工作良好。但是,当信号不稳定时(数据覆盖率可用且反复消失),它会崩溃。几次之后,应用程序在没有任何警告的情况下在try…catch部分崩溃

我需要检查数据覆盖率是否可用,然后不断向服务器发送坐标,否则只需继续检查,直到数据覆盖率可用为止

这是我的密码:

    <!DOCTYPE html>
<html>
  <head>


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

     <script src="jquery-1.5.2.min.js"></script>
     <script src="main.js"></script>
      <script src="jquery.mobile-1.0a4.min.js"></script>
   <script>


    var netCoverage = false;
    var lat='';
    var lon='';


    document.addEventListener("deviceready", onDeviceReady, false);
    document.addEventListener("pause", onDeviceReady, false);






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

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

        //alert('Connection type: ' + states[networkState]);
        if(states[networkState]!=0 && states[networkState]!=6)
                netCoverage = true;
        else
                netCoverage = false;


         }//ends checking for network connection

    var watchID = null;


    function onDeviceReady() {


    checkConnection();







        // Get the most accurate position updates available on the
        // device.
        var options = { maximumAge:30000, enableHighAccuracy: true };
        watchID = navigator.geolocation.watchPosition(onSuccess,
                                                   onError, options);

          // Update compass every 3 seconds
        var watchID = null;
}
        // onError Callback receives a PositionError object
        //
        function onError(error) {
       alert('code: '+ error.code+'\n'+'message:'+ 
                                               error.message + '\n');
        }

$(document).ready(function() {

     /*****************************/
    (function worker() {
        try{                  

           if(netCoverage){             
                 $.ajax({url: 'http://www.myurl.com/add_position.php?&lat='
                 +lat+'&lon='+lon,
             success: function(data) {
            $("#geo_info").text(data);
            accIndex=0;//reset after submitting to server
              },
        error: function(request, error){
            $("#geo_info").text("Network error: "+error);
            $.ajax(this);
            return;
        },
        complete: function() {
        // Schedule the next request when the current one's complete
        setTimeout(worker, 30000);
        }
        });
        }//ends checking for connection
        else{
          $("#geo_info").text('Unknown or no network connection.');
          setTimeout(worker, 30000);      //After calling this 
         //method few times      in              weak data coverage,
          // the app crashes with no warning
        }
        }catch(err){

        $("#geo_info").text('ALMOST CRASHED, '+err.message);

             $.ajax(this);
        return;
        }


        })();

    /*************************************************/
});

    </script>
  </head>
  <body>
    <p id="geo_info">Watching geolocation...</p>
        <button onclick="clearWatch();">Clear Watch</button>


  </body>
</html>

var netCoverage=false;
var lat='';
var-lon='';
文件。添加的监听器(“deviceready”,OnDeviceraddy,false);
文件。添加的监听器(“暂停”,OnDevicerady,false);
函数checkConnection(){
var networkState=navigator.network.connection.type;
变量状态={};
状态[Connection.UNKNOWN]=0;/“UNKNOWN Connection”;
状态[Connection.ETHERNET]=1;//“ETHERNET Connection”;
状态[Connection.WIFI]=2;/“WIFI连接”;
状态[Connection.CELL_2G]=3;/“CELL 2G Connection”;
状态[Connection.CELL_3G]=4;//“CELL 3G Connection”;
状态[Connection.CELL_4G]=5;/“CELL 4G连接”;
状态[Connection.NONE]=6;/“无网络连接”;
//警报('连接类型:'+状态[网络状态]);
如果(状态[网络状态]!=0和状态[网络状态]!=6)
净覆盖率=真;
其他的
网络覆盖率=假;
}//结束网络连接检查
var-watchID=null;
函数ondevicerady(){
检查连接();
//在上获取最准确的位置更新
//装置。
var选项={maximumAge:30000,enableHighAccurance:true};
watchID=navigator.geolocation.watchPosition(onSuccess,
onError,期权);
//每3秒更新一次罗盘
var-watchID=null;
}
//OneError回调接收PositionError对象
//
函数onError(错误){
警报('code:'+错误。code+'\n'+'消息:'+
错误。消息+'\n');
}
$(文档).ready(函数(){
/*****************************/
(职能工作人员(){
试试{
如果(网络覆盖){
$.ajax({url:'http://www.myurl.com/add_position.php?&lat='
+lat+'&lon='+lon,
成功:功能(数据){
$(“#地理信息”)。文本(数据);
accIndex=0;//提交到服务器后重置
},
错误:函数(请求、错误){
$(“#地理信息”).text(“网络错误:+错误);
$.ajax(这个);
回来
},
完成:函数(){
//在当前请求完成时安排下一个请求
setTimeout(工人,30000);
}
});
}//结束连接检查
否则{
$(“#地理信息”).text('未知或无网络连接');
setTimeout(worker,30000);//调用此
//方法在弱数据覆盖情况下进行多次,
//应用程序在没有警告的情况下崩溃
}
}捕捉(错误){
$(“#geo_info”).text('几乎崩溃,'+错误消息);
$.ajax(这个);
回来
}
})();
/*************************************************/
});
观看地理定位

清表
为什么不收听&event

在线

当应用程序联机且设备连接到Internet时,将触发此事件

document.addEventListener("online", yourCallbackFunction, false);
document.addEventListener("offline", yourCallbackFunction, false);
离线

当应用程序脱机且设备未连接到Internet时,将触发该事件

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

希望这对你有帮助

请花点时间正确格式化代码。它使你和其他人更容易阅读。