35

一个非常菜鸟的问题:

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

.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});

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

4

2 回答 2

47

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

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

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

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

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

于 2013-10-14T22:20:34.580 回答
8

我建议你使用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();

       ....

}
于 2013-10-14T17:50:49.410 回答