Angular $ http.get()在Phonegap DevApp中不起作用

时间:2016-01-06 14:01:07

标签: javascript android angularjs cordova phonegap-plugins

对于我的Phonegap应用程序,我正在尝试使用angulars $ http加载JSON文件。

我得到了这项服务:

cApp.factory('language', function ($http) {
    return {
        getLanguageData: function () {
            return $http.get('../../lang/' + lang.substr(0,2) + '.json');
        }
    }
});

我在此控制器中使用的内容:

cApp.controller('initController', function ($scope, language) {   
    language.getLanguageData().success(function (data) {        
        $scope.language = data;
    }).catch(function (e) {
        alert("error" + e);
    });
});

这在我的浏览器中运行良好,但在Android上的Phonegap Developerapp中没有。控制器不会写language变量,也不会发出任何警报(甚至不是“错误”)。

我尝试了什么:

使用.catch().then().catch()链,它会返回上一个null.catch()的数据。

我想知道它是否是跨源问题,但我的phonegap白名单允许所有域(<access origin="*" />)。

文件应该在同一个域中,因为我的文件夹结构如下所示:

.myapp
├── www
|   ├── js
|   |   ├── controller
|   |   |   └── initController.js
|   |   └── service
|   |       └── language.js
|   └── lang
|       ├── en.json
|       └── de.json
└── config.xml

我做错了什么,不见了?

更新:找到部分解决方案:

如果我使用整个路径执行get(),它会起作用:

return $http.get('file:///data/data/com.adobe.phonegap.app/files/phonegapdevapp/www/json/lang/' + lang.substr(0,2) + '.json');

这不是一个合适的解决方案,因为它不适用于iOS(不同路径)。我不明白为什么我不能使用../../lang/

1 个答案:

答案 0 :(得分:0)

您应该使用file-api for cordova个应用将其作为文件处理。