一个非常菜鸟的问题:
我正在尝试使用工厂方法构建资源对象:
.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();
....
}