我在Rails 3.2应用程序中按月对里程条目进行分组:
mileages_controller.rb
def index
@mileages = Mileage.find_all_by_user_id(current_user.id)
@mileages_months = Mileage.find_all_by_user_id(current_user.id).group_by { |t| t.created_at.beginning_of_month }
respond_to do |format|
format.html # index.html.erb
format.json { render json: @mileages }
end
end
index.html.erb
<% @mileages_months.sort.each do |month, mileages| %>
<h4><%= month.strftime('%B %Y') %></h4>
<p>Total miles <strong><%= mileages.miles.sum %></strong>.</p>
<table>
<tr>
<th>Name</th>
<th>Miles</th>
<th>Start</th>
<th>Destination</th>
<th></th>
</tr>
<% for mileage in mileages %>
<tr>
<td><%= mileage.name %></td>
<td><%= mileage.miles %></td>
<td><%= mileage.start %></td>
<td><%= mileage.end %></td>
<td><%= link_to 'Show', mileage %></td>
</tr>
<% end %>
</table>
<% end %>
如您所见,我正在尝试使用<%= mileages.miles.sum %>
对每个月的总里程求和。这不起作用 - 但<%= mileages.first.miles %>
正确显示每个月的第一个条目里程。
每月总计里程列的正确方法是什么?
答案 0 :(得分:1)
你可以在mileage_helper
中创建一个帮助方法(以保持逻辑与视图分离):
def sum_mileges(mileages)
mileages.map(&:miles).sum
end
然后在视图中将其称为
<p>Total miles <strong><%= sum_mileges(mileages) %></strong>.</p>
OR
你可以直接做到:
<p>Total miles <strong><%= mileages.map(&:miles).sum %></strong>.</p>