AngularJS:$资源与嵌套资源

前端之家收集整理的这篇文章主要介绍了AngularJS:$资源与嵌套资源前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我使用AngularJS $资源模型来REST API.我有这样的东西:
angular.module('libraryapp')
    .factory('Book',function($resource){
        return $resource('books/:id');
    });

我以这种方式使用:

Book.get({ id: 42 },function(book) {
    console.log(book);
});

但是我也想要一个端点到子资源,让我们说:

GET /books/:id/comments

我应该如何在模块中定义它?我可以以某种方式延长书本,这样使用它

Book.get({ id: 42 }).Comment.query(function(comments) {
    console.log(comments);
});
您可以使用AngularJS $资源定义轻松访问嵌套的RESTful资源.

线索是了解$resource定义中每个动作定义(在动作列表中)的params参数的工作原理.正如文档所说,这是一个

Optional set of pre-bound parameters for this action. […]

angular.module('libraryApp').factory('Book',[
  '$resource',function($resource) {
    return $resource('books/:id/:subResource',{},{
      comments: {  // The `comments` action definition:
        params: {subResource: 'comments'},method: 'GET'
      }
    });
  }
]);

鉴于上述定义,您仍然可以像以前一样使用Book.例如Book.get({id:42})转换为GET书籍/ 42 /请求.

但是,给定$资源URL(‘books /:id /:subResource’)的新的:subResource部分,现在可以生成

GET books/42/comments

通过调用Book.get({id:42,subResource:’comments’})或者定义为您的评论动作的更简洁和优雅的Book.comments({id:42})接口来进行请求.

猜你在找的Angularjs相关文章