36

由于运行经典 ASP 的服务器的限制,我的服务必须使用查询字符串:

angular
  .module('myServices', ['ng', 'ngResource'])
  .factory('Item', ['$resource',
     function ($resource) {
         return $resource('/api/?p=item/:id');
     }]);

我想向它添加额外的查询字符串参数:

Item.query({test: 123}, on_success, on_error);

但生成的网址是

/api/?p=item?test=123

显然有一个错误,但如何解决它?

编辑:在https://github.com/angular/angular.js/issues/1511提交

4

2 回答 2

71

您可以使用资源参数。如果您没有在路径中指定占位符,它们将自动转换为查询字符串参数。像那样:

angular
    .module('myServices', ['ng', 'ngResource'])
    .factory('Item', [
         '$resource',
         function ($resource) {
             return $resource('/api');
     }]);

Item.query({p: 'item/1'});

这将导致请求/api?p=item/1.

附言

我想你已经知道了,但你不喜欢它。但我仍然认为这是你的正确方法。考虑到您正在处理该后端的糟糕 API 设计,您可以将 AngularJS 资源与另一个为您执行此操作的服务包装在一起。

于 2012-11-11T08:04:52.493 回答
0
var deferred = $q.defer();
api.api_name.query({
    'param':param_value
},
    function(response) {
        deferred.resolve(response);
    },
    function(response) {
        deferred.reject(response);
    }
);
//
angular
    .module('module_name')
    .factory('api',function($resource){
        var api_var={};
        api_var.api_name = $resource('url?param_key=:param', {
            param: '@param'
        }, {
            'query': {
                method: 'get'
            }
        });
        return api_var;
    });
于 2017-05-06T10:27:27.603 回答