diff options
author | Mike Gunderloy <MikeG1@larkfarm.com> | 2008-10-16 18:47:47 -0500 |
---|---|---|
committer | Mike Gunderloy <MikeG1@larkfarm.com> | 2008-10-16 18:57:42 -0500 |
commit | 03626f0c13c0205becf04d8a47ee1e9bf4b80cb4 (patch) | |
tree | 9630328cebe0d601109d6b695b4d9938f4072846 /railties | |
parent | 086c8c28c9a3cd17bcb1765e870a9563b71af1fd (diff) | |
download | rails-03626f0c13c0205becf04d8a47ee1e9bf4b80cb4.tar.gz rails-03626f0c13c0205becf04d8a47ee1e9bf4b80cb4.tar.bz2 rails-03626f0c13c0205becf04d8a47ee1e9bf4b80cb4.zip |
Additional detail on rendering partials
Diffstat (limited to 'railties')
-rw-r--r-- | railties/doc/guides/actionview/layouts_and_rendering.txt | 46 |
1 files changed, 45 insertions, 1 deletions
diff --git a/railties/doc/guides/actionview/layouts_and_rendering.txt b/railties/doc/guides/actionview/layouts_and_rendering.txt index 00f9dbbdd9..db6d8b3517 100644 --- a/railties/doc/guides/actionview/layouts_and_rendering.txt +++ b/railties/doc/guides/actionview/layouts_and_rendering.txt @@ -635,6 +635,17 @@ Here, the +_ad_banner.html.erb+ and +_footer.html.erb+ partials could contain co TIP: For content that is shared among all pages in your application, you can use partials directly from layouts. +==== Partial Layouts + +A partial can use its own layout file, just as a view can use a layout. For example, you might call a partial like this: + +[source, html] +------------------------------------------------------- +<%= render :partial => "link_area", :layout => "graybar" %> +------------------------------------------------------- + +This would look for a partial named +_link_area.html.erb+ and render it using the layout +_graybar.html.erb+. Note that layouts for partials follow the same leading-underscore naming as regular partials, and are placed in the same folder with the partial that they belong to (not in the master +layouts+ folder). + ==== Passing Local Variables You can also pass local variables into partials, making them even more powerful and flexible. For example, you can use this technique to reduce duplication between new and edit pages, while still keeping a bit of distinct content: @@ -711,6 +722,40 @@ You can also specify a second partial to be rendered between instances of the ma Rails will render the +_product_ruler+ partial (with no data passed in to it) between each pair of +_product+ partials. +There's also a shorthand syntax available for rendering collections. For example, if +@products+ is a collection of products, you can render the collection this way: + +[source, html] +------------------------------------------------------- +index.rhtml.erb: + +<h1>Products</h1> +<%= render :partial => @products %> + +_product.html.erb: + +<p>Product Name: <%= product.name %></p> +------------------------------------------------------- + +Rails determines the name of the partial to use by looking at the model name in the collection. In fact, you can even create a heterogeneous collection and render it this way, and Rails will choose the proper partial for each member of the collection: + +[source, html] +------------------------------------------------------- +index.rhtml.erb: + +<h1>Contacts</h1> +<%= render :partial => [customer1, employee1, customer2, employee2] %> + +_customer.html.erb: + +<p>Name: <%= customer.name %></p> + +_employee.html.erb: + +<p>Name: <%= employee.name %></p> +------------------------------------------------------- + +In this case, Rails will use the customer or employee partials as appropriate for each member of the collection. + == Changelog == http://rails.lighthouseapp.com/projects/16213-rails-guides/tickets/15[Lighthouse ticket] @@ -758,4 +803,3 @@ http://rails.lighthouseapp.com/projects/16213-rails-guides/tickets/15[Lighthouse - |