Я пытаюсь снова использовать компонент HTML, что я записал, что это обеспечивает моделирование панели. Что-то как:
<div class="v-panel">
<div class="v-panel-tr"></div>
<h3>Some Title</h3>
<div class="v-panel-c">
.. content goes here
</div>
<div class="v-panel-b"><div class="v-panel-br"></div><div class="v-panel-bl"></div></div>
</div>
Таким образом, я вижу, что рендеринг берет блок. Я фигурировал затем, что я мог сделать что-то вроде этого:
# /shared/_panel.html.erb
<div class="v-panel">
<div class="v-panel-tr"></div>
<h3><%= title %></h3>
<div class="v-panel-c">
<%= yield %>
</div>
<div class="v-panel-b"><div class="v-panel-br"></div><div class="v-panel-bl"></div></div>
</div>
И я хочу сделать что-то как:
#some html view
<%= render :partial => '/shared/panel', :locals =>{:title => "Some Title"} do %>
<p>Here is some content to be rendered inside the panel</p>
<% end %>
К сожалению, это не работает с этой ошибкой:
ActionView::TemplateError (/Users/bradrobertson/Repos/VeloUltralite/source/trunk/app/views/sessions/new.html.erb:1: , unexpected tRPAREN
old_output_buffer = output_buffer;;@output_buffer = ''; __in_erb_template=true ; @output_buffer.concat(( render :partial => '/shared/panel', :locals => {:title => "Welcome"} do ).to_s)
on line #1 of app/views/sessions/new.html.erb:
1: <%= render :partial => '/shared/panel', :locals => {:title => "Welcome"} do -%>
...
Таким образом, этому не нравится =
очевидно, с блоком, но если я удаляю его, затем это просто ничего не производит.
Кто-либо знает, как сделать то, чего я пытаюсь достигнуть здесь? Я хотел бы снова использовать этот HTML панели во многих местах на моем сайте.
Хотя оба приведенных выше ответа работают (ну, пример, на который Тони все равно ссылается), я в конечном итоге нашел наиболее сжатый ответ в этом сообщении выше (комментарий Корнелиса Сиецма)
Я думаю render: layout
делает именно то, что я искал:
# Some View
<%= render :layout => '/shared/panel', :locals => {:title => 'some title'} do %>
<p>Here is some content</p>
<% end %>
в сочетании с:
# /shared/_panel.html.erb
<div class="v-panel">
<div class="v-panel-tr"></div>
<h3><%= title -%></h3>
<div class="v-panel-c">
<%= yield %>
</div>
</div>
Я думаю, что это будет работать (просто сделал быстрый грязный тест), если вы сначала присвоите его переменной, а затем выведете его.
<% foo = render :partial => '/shared/panel', :locals =>{:title => "Some Title"} do %>
<p>Here is some content to be rendered inside the panel</p>
<% end %>
<%= foo %>