AngularJS和Restangular:TypeError:无法读取属性'那么'的未定义

AngularJS and Restangular: TypeError: Cannot read property 'then' of undefined

本文关键字:未定义 属性 那么 读取 Restangular TypeError AngularJS      更新时间:2024-01-11

我构建了一个服务,这个服务返回了一个对象。但是,在我的控制器中,我不处理这个对象,因为".then"不起作用。

我的服务:

var getUser = function(userId) {
    Restangular.all(userId).post(JSON.stringify()).then(function(response) {
        var obj = angular.fromJson(response);
        if (!obj.isError) {
            return obj;
        }
        else {
            console.log("ERRO getUserCard");
        }
    });
};

我的控制器:

var succsess = function(data){
    welcomeScope.getUser = data;
    console.log("getUser: " + welcomeScope.getUser);
};
var error = function(){
    console.log("Erro error");
};
function loadProfile(){ 
    welcomeSvc.getUser("203831").then(success,error);
};

注意:welcomeScope是我的$scope。

您应该在函数getUser 中添加return

var getUser = function(userId){
   return Restangular.all(userId).post(JSON.stringify()).then(function(response){
        var obj = angular.fromJson(response);
        if (!obj.isError) {
            return obj;
        }
        else{
            console.log("ERRO getUserCard");
        }
    });
}; 

getUser()函数需要返回promise:

var getUser = function(userId) {
return new Promise(function(resolve, reject) {
  Restangular.all(userId).post(JSON.stringify()).then(function(response) {
    var obj = angular.fromJson(response);
    if (!obj.isError) {
        resolve(obj);
    }
    else {
        reject(console.log("ERRO getUserCard"));
    }
  })
 })
};

您可能需要将解析、拒绝传递到Restangulars promise