在轨道中具有多个产量的部分

a.s*_*nko 5 model-view-controller templates ruby-on-rails view

我正在寻找具有多个部分的解决方案yields.

在实例中我有这个视图结构:

基本application.erb(/views/layouts/application.erb):

<!DOCTYPE html>
<head>
    <title>Some title</title>
</head>
<body>
<div class="page">
    <%= yield %>
</div>
</body>
</html> 
Run Code Online (Sandbox Code Playgroud)

有些人干我的代码(/views/shared/content.erb):

<div class="content">
    <div class="sidebar">
        <%= yield :sidebar %>
    </div>
    <div class="main">
        <%= yield %>
    </div>
</div>
Run Code Online (Sandbox Code Playgroud)

和控制器视图(/views/home/index.erb):

<%= render :partial => 'layouts/header' %>    
<%= render :partial => 'shared/navigation' %>

<% # It is close to what I want to do %>
<%= render :layout => 'shared/content' do %>
    <% content_for :sidebar do %>
        <%# This is will go to application.erb, not in content.erb %>
        <%= render :partial => 'shared/menu' %>
    <% end %>

    <%= yield %>
<% end %>

<%= render :partial => 'layouts/footer' %>
Run Code Online (Sandbox Code Playgroud)

因此,这里的主要问题是具有多个屈服区域的模板块以及传递自定义html或渲染另一部分的能力.

Wes*_*ter 6

这个问题很老,但是,当我在Google上搜索答案时,这仍然很重要.

我想出了一个解决方案,虽然还不漂亮,但效果很好.这个想法使用Rails的capture方法,它接受一个块并将其内容存储到一个变量中:

controller.html.erb

<%= render 'shared/partial', body: capture { %>
  My body content
<% }, footer: capture { %>
  My footer content
<% } %>
Run Code Online (Sandbox Code Playgroud)

共享/ _partial.html.erb

<div id="body"><%= body %></div>
<div id="footer"><%= footer %></div>
Run Code Online (Sandbox Code Playgroud)

希望这有助于某人!


a.s*_*nko 4

就我而言,我找到了这样的解决方案。

在我的控制器视图(/views/home/index.erb)上:

<% sidebar_content = render :partial => 'shared/slider' %>
<%= render :layout => 'shared/content', :locals => {:sidebar => sidebar_content} do %>
    <%= yield %>
<% end %>
Run Code Online (Sandbox Code Playgroud)

具有多个区域的部分(/views/shared/content.erb):

<div class="content">
    <div class="sidebar">
        <%= sidebar %>
    </div>
    <div class="main">
        <%= yield %>
    </div>
</div>
Run Code Online (Sandbox Code Playgroud)

这个解决方案看起来不太漂亮,但是很有效。我希望在不久的将来能找到更好的东西。