Render partial with collection has "hidden" index
Wen rendering a partial with a collection, sometimes is necessary an index to apply some css class or other stuff.
I recently found an "undocumented" feature, inside partial exist "#{partial_name}_counter"
with the iteration index. https://github.com/rails/rails/blob/4-0-stable/actionpack/lib/action_view/renderer/partial_renderer.rb#L480
For example, usual post rendering:
<%= render partial: 'post', collection: @posts %>
Inside _post.html.erb we can do something like this:
<% index = post_counter + 1 %>
<%= content_tag :div, class: "post-#{index}" do %>
content...
<% end -%>
I only try it in Rails 4, I don't know if it works in previous versions.
Written by Victor Ortiz
Related protips
6 Responses
data:image/s3,"s3://crabby-images/19fd3/19fd394bd00207cfc50c18d8192a69c52b5db59f" alt=""
Awesome little find! You got good eyes.
data:image/s3,"s3://crabby-images/984f2/984f21d676cd7a706ae4c60bb5db12a8b245d91a" alt=""
Tested in Rails 3, it works also.
Cool, thanks!
data:image/s3,"s3://crabby-images/9a964/9a9647582da1506a61514e978adfdbba2108a2e0" alt=""
Your render line can be shortened:
<%= render @posts %>
Rails understands that @posts is a collection of Post models and will render each with the _post.html.erb template.
Typo:
The variable name is not #{partial_name}_counter
, in fact it is #{variable_name}_counter
<%= render partial: "post", collection: @posts %>
makes the counter post_counter
.
<%= render partial: "my_partial", collection: @items, as: :item %>
makes the counter item_counter
.
data:image/s3,"s3://crabby-images/7b23f/7b23f66091b05ffaaef2b442d1ab9406886c32e7" alt=""
Works in Rails 5