3

我正在尝试获取MotorRestangular.all('Motors').getList()分配给变量的响应,a以便以后可以使用它。问题是,如果我尝试访问a我的return函数内部,它是未定义的。我知道这不是完成我需要的正确方法,但我不知道如何以任何其他方式做到这一点。

myApp.factory('Configurations', function(Restangular, MotorRestangular) {
  var a;
  var Motors = function() {
    MotorRestangular.all('Motors').getList().then(function(Motors){
      a = Motors;
    }); 
  }



  return {
    config: function(){
      Motors();
      console.log(a);
      var g = _.groupBy(Motors, 'configuration');
      console.log(g);
      var mapped = _.map(g, function(m) {
        return {

            id: m[0].configuration,
            configuration: m[0].configuration,
            sizes: _.map(m, function(a) {return a.sizeMm})
      }});
    }
  }

});
4

2 回答 2

7

请不要使用延迟对象。如果您在回答中的内容有效 - 那么这也将有效:

myApp.factory('Configurations', function (Restangular, MotorRestangular, $q) {
    var getConfigurations = function () {
        return MotorRestangular.all('Motors').getList().then(function (Motors) {
            //Group by Cofig
            var g = _.groupBy(Motors, 'configuration');
            //Map values
            return _.map(g, function (m) {
                return {
                    id: m[0].configuration,
                    configuration: m[0].configuration,
                    sizes: _.map(m, function (a) {
                        return a.sizeMm
                    })
                }
            });
        });
    };

    return {
        config: getConfigurations()
    }

});

此外,如果发生错误,返回的 Promise 不会永远挂起。

于 2013-10-21T07:25:25.790 回答
1

我刚刚解决了这个问题。发生的事情是在被填充config:之前返回。a下面的代码有效。

myApp.factory('Configurations', function(Restangular, MotorRestangular, $q) {
  var getConfigurations = function(){
    var deferred = $q.defer();

    MotorRestangular.all('Motors').getList().then(function(Motors){
      //Group by Cofig
      var g = _.groupBy(Motors, 'configuration');
      //Map values
      var mapped = _.map(g, function(m) {
        return {
            id: m[0].configuration,
            configuration: m[0].configuration,
            sizes: _.map(m, function(a) {return a.sizeMm})
      }});
      deferred.resolve(mapped);
    });
    return deferred.promise;
  };

  return {
    config: getConfigurations()
  }

});
于 2013-10-21T05:14:27.230 回答