我应该何时在Rails中创建单独的控制器而不是自定义操作?

Rob*_*ers 6 ruby-on-rails controllers

考虑一个我有Orders模型的例子.触发index操作会显示系统中的所有订单.

现在我想要一个单独的页面显示所有已退款订单的图表,另一个页面显示所有已取消的订单 - 不仅现在有一个过滤器,而且还有一个全新的视图.

什么是最佳做法:

1.)OrdersController为每个报告创建新的操作(例如,refund_reportcancelled_report)

2.)通过单个操作为每个报告创建新的控制器(例如RefundReportController,CancellationReportController)show

3)为所有人创造一个报告新的控制器(例如,OrderReportsController)和每个报告的动作(例如refunds,cancellations等等.

或者还有另一种我完全不知道的范例?

pdo*_*obb 6

使用#1:OrdersController为每个报告创建操作.这很简单,资源(a Order)通过其关联的控制器可以有多个视图.你还没有要求任何特定于这些报告之一的东西,它是一个好的/简单的模式1:获取动作(和路线)对应于1个视图.

如果您将来发现自己正在做一些特定于报告的事情,那么请考虑将该报告作为自己的控制器.但这可能永远不会发生,也不需要提前抽象,现在就要压低自己.

基本上,当您想要开始将该事物视为具有自己动作的自己的实体时,创建一个新的Controller.不要因为默认的REST选项没有为您需要的内容提供特定的成员操作而将某些内容分解为新的控制器.