1

我对 Angular 有点陌生,我正在尝试设置一个非常简单的 RPC 实现,它使用 angulars$http服务(工厂)来完成这项工作。到目前为止,这是我所拥有的服务:

'use strict';

angular.module('xxx')
  .factory('rpcService', function ($http) {

    return {
      request: function(method, params, callback) {
        var service = method.split('.');
        params = params || {};
        params.method = service[1];
        return $http.post('/services/' + service[0] + '.sjs', params).then(function (response) {
            return response.data;
        });
      }
    }

  });

然后当我想使用该服务时,我将其称为如下:

rpcService.request('Users.facebookLogin', { token: response.authResponse.accessToken })
  .then(function(response) {
    debugger;
    $rootScope.user = response.user;
    console.log($rootScope.user);
    $rootScope.loggedIn = true;
    $rootScope.$apply();
});

代码在调试器之后永远不会到达行;事实上,代码根本不会发出$http请求。由于某种原因,它停止并且不会继续回调......或承诺......我对技术差异是什么感到有点困惑。:)

话虽如此,我已经测试了 POST 调用$.ajax并且一切都正常返回,所以我的 Angular 代码有些问题。

实际触发请求并使用的代码$.ajax

'use strict';

angular.module('xxx')
  .factory('rpcService', function ($http) {

    return {
      request: function (method, params, callback) {
        var service = method.split('.');

        params = params || {};
        params.method = service[1];

        $.ajax('/services/' + service[0] + '.sjs', {
          type: 'POST',
          dataType: 'json',
          data: params,
          success: function(data, status, xhr) {
              if (callback) {
                  callback(data);
              }
          }
        });
      }
    }      
  });

我只是不确定为什么没有提出 XHR 请求。

4

1 回答 1

2

API 调用可能会出错,因此从未触发回调。尝试error()像这样添加回调:

return $http("POST", '/services/' + service[0] + '.sjs', params)
    .error(function (response) {
        return 'blah';
    }).then(function (response) {
        return response.data;
    });

你可以在这个演示上试试。您的代码实际上看起来不错。

Demo on jsFiddle

于 2013-07-31T18:02:19.227 回答