在服务中使用$ routeParams

时间:2014-02-21 15:16:21

标签: angularjs angularjs-service

我正在尝试将查询参数附加到我从URL中获取的所有API调用。

factory('Post', function ($resource, $routeParams) {
    return $resource('api/posts', {customer_id: $routeParams.customerId});
})

第一次使用Post服务时这是有效的,但是第二次注入时它已经被初始化并且正在使用第一个客户ID,即使URL已经改变。

如何按预期进行此项工作?

1 个答案:

答案 0 :(得分:6)

因为服务是单身人士。 这就是你得到这种行为的原因。

我建议不要将$ routeParams作为服务的init参数注入。 相反,将它注入控制器,然后使用$ routeParams中的值作为参数调用服务的函数。

代码可能是这样的:

factory('Post', function ($resource) {
    return {
        doPost: function(customerId) {
            $resource('api/posts', {customer_id: customerId});
        }
    };
});

//...
//in some controller
Post.doPost($routeParams.customerId)