[英]How do implement many-to-many relationships in a Laravel 4 RESTful API
我想实现类似于Laravel 4中这个问题的要求,其中一个player/
资源可以有多个team/
,反之亦然。
在理想的世界中,我将能够查询
players/1/teams
然后像这样返回一些JSON:
{ player: {
id: 1, name: 'Bob', sport: 'Curling', teams: [
{ id: 1, name: 'Northern Curling Soc.', age: 2},
{ id:2, name: 'Southern Curling Soc.', age: 4 }
]
}
要么
teams/{id}/players
并获得相关性。
显然,如果我使用Laravel的视图,我可以简单地调用$player->teams
,一切都会好起来的,但这是针对JSON API的,因此所有这些都需要预先准备。
我还需要能够对相关结果进行分页,尽管这可能是一个不同的问题。
我如何用Laravel做到这一点?
谢谢你的帮助!
Laravel 4增加了对嵌套资源路由的支持。 它们非常好,并且似乎非常适合于此。
基本上,除了“直接”资源控制器之外,您还需要为嵌套资源添加路由。 在这种情况下,除了:
Route::resource('players', 'PlayersController'); // players/#
Route::resource('teams', 'TeamsController'); // teams/#
...您需要:
Route::resource('players.teams', 'PlayerTeamsController'); // players/#/teams/#
Route::resource('teams.players', 'TeamPlayersController'); // teams/#/player/#
然后,在您的控制器中,通常将单个ID作为参数的方法现在将收到两个(顺序由您的路线定义):
class PlayerTeamsController extends Controller {
public function show($player_id, $team_id) {
}
}
然后,您可以使用继承来避免控制器之间的代码冗余。
通过API,只需包含关系并返回对象(在laravel 4中)。 L4将自动格式化数据以进行JSON输出。
return Player::with( [ 'teams' ] )->get();
它会给您几乎完全一样的格式:)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.