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或渲染另一部分的能力.
这个问题很老,但是,当我在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)
希望这有助于某人!
就我而言,我找到了这样的解决方案。
在我的控制器视图(/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)
这个解决方案看起来不太漂亮,但是很有效。我希望在不久的将来能找到更好的东西。
| 归档时间: |
|
| 查看次数: |
2830 次 |
| 最近记录: |