angularjs – 如何在角度服务中使用带有promise模式的restangular

前端之家收集整理的这篇文章主要介绍了angularjs – 如何在角度服务中使用带有promise模式的restangular前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个服务与休息角度与以下结构

function countrySvc(restangular) {
    restangular.addResponseInterceptor(function (data,operation,what,url,response,deferred) {

        if (operation === 'getList') {
            var newResponse = response.data;

            return newResponse;
        }
        return response;
    });
    var baseCountry = restangular.all('country');


    this.countries = function() {

        baseCountry.getList();

    };
}

也是一个控制器

function countryCtrl(scope,countrySvc) {


    scope.countries = countrySvc.countries();

}

但是当我从控制器访问国家时,结果是空的,并且数据成功请求,我的问题是如何从具有正确承诺模式的响应中提取数据,即(当我访问scope.countries时我需要一组国家/地区)

解决方法

你需要解决承诺……

有两种方法可以做到……

1)使用$object

只需添加.$object即可结束承诺,一旦请求完成,它就会解除承诺……

scope.countries = countrySvc.countries().$object;

2)然后使用

如果你需要在承诺解决后需要做一些东西选择这个选项,一旦请求完成回调函数然后将被触发

scope.countries = countrySvc.countries().then(function (response){
    // DO SOMETHING IF YOU NEED BEFORE SET OBJECT
    scope.countries = response;
    // DO SOMETHING IF YOU NEED AFTER SET OBJECT
});

猜你在找的Angularjs相关文章