1

我正在制作一个 phonegap 应用程序(phonegap 2.9 + jquery 1.8.3 + jquery mobile 1.3.1)它在 -4.3 android 设备中完美运行。-4.0 安卓设备。-2.2 安卓虚拟设备。

问题是我在 android 2.2.2 设备中安装它时遇到了一些问题。一些 api 调用有效,而另一些则无效。

例如,此调用有效:

$.ajax({
    data:   {museum_id:'1'},
    url:    url+'index.php?r=api/ListAllCuriosities',
    type:   'get',
    success:  function (response) {
        var resultado = response['data'];
        var listadohtml = '';
        for (var i=0;i<resultado.length;i++){
            listadohtml += '<ul data-role="listview" data-theme="b" class="titulos"><li>'+resultado[i]['title']+'</li></ul>'
                        +'  <p>'+ resultado[i]['description']+'</p>';
        }

        $('#listCuriosities').html(listadohtml);
        $('#listCuriosities').trigger('create');
    },
    error: function() {
        //something went wrong, handle the error and display a message
        alert('Se ha producido un error en la llamada al servidor');
    }
});

但这另一个没有

$.ajax({
    data:   {museum_id:'1'},
    url:    url+'index.php?r=api/ListMasterpieces',
    type:   'get',
    success:  function (response) {
        var visitedList = JSON.parse(window.localStorage.getItem("visited"));
        var resultado = response['data'];
        var listadohtml = '<div>';
        var author = '';


        for (var i=0;i<resultado.length;i++){
            var item = '';
            var isVisited = 'data-theme="a"';

            if(visitedList!=null && resultado[i]['id'] in visitedList && visitedList[resultado[i]['id']]==1){
                isVisited = 'data-theme="b" data-icon="check"';
            }

            if(resultado[i]['authorname']!=author){ // en caso de que el autor haya cambiado se insertará una nueva línea
                item += '<ul data-role="listview" data-theme="b"><li>'+resultado[i]['authorname']+'</li></ul>';
                author = resultado[i]['authorname'];
            }
            var id = resultado[i]['id'];
            item += '<p><a href="detalle.html?id='+id+'" id="enlace-'+id+'" data-role="button" data-ajax="false" data-prefetch="false" '+isVisited+'>'+resultado[i]["name"] + '</a></p>';

            listadohtml += item;
        }
        listadohtml += '</div>';


        $('#listaMasterpieces').html(listadohtml);
        $('#listaMasterpieces').trigger('create');
    },
    error: function() {
        //something went wrong, handle the error and display a message
        alert('Se ha producido un error en la llamada al servidor');
    }
});

我认为它可能是:-由于 aa 权限问题(如您所见,我在设备中存储了一些信息)-因为 jquery 无法正常工作(我没有看到错误 ajax-method 的警报)

我附上我的清单:

<supports-screens android:largeScreens="true" android:normalScreens="true" android:smallScreens="true" android:resizeable="true" android:anyDensity="true" />

 <uses-permission android:name="android.permission.READ_PHONE_STATE" />
 <uses-permission android:name="android.permission.INTERNET" />
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
 <uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="17" />

 <application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.museum.prado.MainActivity"
        android:label="@string/app_name" 
        android:configChanges="orientation|screenSize" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
 </application>

提前致谢

4

1 回答 1

0

感谢@Raoul George,我发现了问题所在。

当你做:

var visitedList = JSON.parse(window.localStorage.getItem("visited"));

在 android 4 中没有任何反应,但如果您使用 android 2.2,则需要确保 window.localStorage.getItem("visited") 具有值。

于 2013-08-13T10:06:59.350 回答