使用资源服务时如何传入参数



一个非常菜鸟的问题:

我正在尝试使用工厂方法构建资源对象:

.factory('Magazines', [function ($resource) {
    var url = document.URL;
    var urlArray = url.split("/");
    var organId = urlArray[urlArray.length-1];
    return $resource('http://localhost/ci/api/magazines/:id', {
        loginID : organEntity,
        password : organCommpassword,
        id : organId
    });
  }])

这种方法很容易,因为所有参数都是预定义的,organEntity 和 organCommpassword 都在标签内定义。

现在对于不同的资源对象,我需要在调用工厂时传入参数。

我想这个资源对象的调用代码应该看起来像:

.controller('ResrouceCtrl', function($scope, Magazines) {
      $scope.magazines = Magazines.query();
});

我知道 query() 方法可以添加参数:Magazines.query(params, successcb, errorcb);

我想知道如果我只是传入参数,我可以在工厂获得参数吗?如何在工厂方法中指定这样的传入参数?

例如,现在假设我不能再从 url 获取 organId,我需要从我的控制器传入它,如何在工厂方法中接收 organId?


这是我的资源js:

.factory('MagComments', function ($resource) {

    return $resource('http://localhost/dooleystand/ci/api/magCommenct/:id', {
      loginID : organEntity,
      password : organCommpassword,
      id : '@magId' //pass in param using @ syntax
    });
  })

这是我的控制器:

$scope.magComments = MagComments.query({magId : 1});

我尝试传入参数,但它导致错误

我想我看到了你的问题,你需要使用@语法来定义你将以这种方式传递的参数,我也不确定登录ID或密码在做什么你似乎没有在任何地方定义它们,它们没有被用作URL参数,所以它们是否作为查询参数发送?

这是我根据目前所看到的情况可以建议的:

.factory('MagComments', function ($resource) {
    return $resource('http://localhost/dooleystand/ci/api/magCommenct/:id', {
      loginID : organEntity,
      password : organCommpassword,
      id : '@magId'
    });
  })

@magId字符串将告诉资源将:id替换为作为参数传递的对象上的属性magId

我建议非常仔细地阅读这里的文档(我知道它有点不透明),并在最后查看示例,这应该会有很大帮助。

我建议你使用provider .当您想先配置它然后再使用时,提供是好的(针对服务/工厂)

像这样:

.provider('Magazines', function() {
    this.url = '/';
    this.urlArray = '/';
    this.organId = 'Default';
    this.$get = function() {
        var url = this.url;
        var urlArray = this.urlArray;
        var organId = this.organId;
        return {
            invoke: function() {
                return ......
            }
        }
    };
    this.setUrl  = function(url) {
        this.url = url;
    };
   this.setUrlArray  = function(urlArray) {
        this.urlArray = urlArray;
    };
    this.setOrganId  = function(organId) {
        this.organId = organId;
    };
});
.config(function(MagazinesProvider){
    MagazinesProvider.setUrl('...');
    MagazinesProvider.setUrlArray('...');
    MagazinesProvider.setOrganId('...');
});

现在控制器:

function MyCtrl($scope, Magazines) {        
        Magazines.invoke();
       ....
}

最新更新