这只是突然开始发生的事情:我的老板在短途旅行中将手机和该应用程序的开发副本一起拿了起来,并在旅途中报告了此错误。我以为我已经对从服务器返回的json进行了一些更改,使它中断了,但是现在我将其恢复了,这似乎与我在服务器上的工作完全无关。

这是我在控制台中收到的错误消息:

Error in success callback: Geolocation3 = ReferenceError: Can't find variable: jQuery

要么
Error in success callback: Geolocation3 = ReferenceError: Can't find variable: $

很明显,它只是找不到jQuery。它执行'deviceReady'就好了。但是它在模拟器中可以正常工作。我同时将jQuery CDN用于jQM和jQ,并且可以通过浏览器访问这两者。

那有什么呢?为什么突然无法在设备上找到jQuery?

我在网络上看到很多类似的问题,但没有一个有明确的答案。有些是“清理并重建”的,有些则是简单的错别字。这不是位置权限问题。这不是连接问题。这不是url白名单问题。

一如既往地感谢您的帮助。谢谢!

我将在下面提供尽可能多的代码:
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, user-scalable=no">
    <title>XXXXXX</title>
    <link rel="stylesheet" href="css/jquery.mobile.css" />
    <link rel="stylesheet" href="css/themes/app-2012-11-30.css" />
    <link rel="stylesheet" type="text/css" href="spec/lib/photoswipe/photoswipe.css" />
    <link rel="stylesheet" type="text/css" href="css/index.css" />
    <!-- cordova -->
    <script src="cordova-2.1.0.js" type="text/javascript"></script>
    <!-- jquery -->
    <script src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script>
    <!-- Google -->
    <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>
    <!-- Add ons -->
    <script src="spec/lib/photoswipe/lib/klass.min.js"></script>
    <script src="spec/lib/photoswipe/code.photoswipe.jquery-3.0.5.js"></script>
    <!-- Objects -->
    <script src="js/map.js" type="text/javascript"></script>
    <script src="js/prefs.js" type="text/javascript"></script>
    <script src="js/search.js" type="text/javascript"></script>
    <script src="js/storage.js" type="text/javascript"></script>
    <script src="js/helpers.js" type="text/javascript"></script>
    <script src="js/player.js" type="text/javascript"></script>
    <script src="js/record.js" type="text/javascript"></script>
    <script src="js/connection.js" type="text/javascript"></script>
    <script src="js/location.js" type="text/javascript"></script>
    <script src="js/header-footer.js" type="text/javascript"></script>
    <script src="js/featured.js" type="text/javascript"></script>
    <script src="js/list.js" type="text/javascript"></script>
    <script src="js/index.js" type="text/javascript"></script>
    <script type="text/javascript">
        document.addEventListener("deviceready", onDeviceReady, false);
        function onDeviceReady(){
            console.log('device ready');
            storageSetUp();
            checkConnection();
            getLocation();
            showFeatured();
            getSetUp();
            clUpdate();
            $(document).bind( 'mobileinit', function(){
                $.mobile.defaultPageTransition = "none";
                $.mobile.loader.prototype.options.textVisible=false;
                $.mobile.loader.prototype.options.html = '<div class="loading"></div>';
                $.mobile.pushStateEnabled = false;
            });
            $(document).bind('pagebeforeshow',function(){
                setHeaderFooterInfo();
            });
        }
    </script>

getLocation在.js文件中。您在那里看到函数getStreetAddress,它包含一个ajax调用($ .ajax或jQuery.ajax),这就是错误的出处。
function getLocation()
{
    gLAttempt++;
    navigator.geolocation.getCurrentPosition(onLocationSuccess, onLocationError);
}

// onSuccess Geolocation
function onLocationSuccess(position)
{
    var lat = position.coords.latitude;
    var lng = position.coords.longitude;
    Storage.location.lat = parseFloat(lat.toFixed(6));
    Storage.location.lng = parseFloat(lng.toFixed(6));
    Storage.location.coords = lat.toFixed(6) + ',' + lng.toFixed(6);
    if(ajax_rg == null){
        getStreetAddress(Storage.location.coords);
    }
}

最佳答案

我可以想到2种可能的情况:

  • iOS设备使用文件/文件夹名称区分大小写。确保对所有添加的文件和文件夹使用相同的大小写。请记住,iOS模拟器不区分大小写。因此,不区分大小写的文件引用将在模拟器上起作用,但在设备上不起作用。
  • 从CDN中删除jQuery引用,并将其本地添加。在打包应用程序并进行部署时,使用CDN并没有任何意义。可能会触发您的onDeviceReady事件,但未从CDN下载jQuery文件...
  • 09-10 11:13
    查看更多