首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >haml、blocks和partials

haml、blocks和partials
EN

Stack Overflow用户
提问于 2012-07-13 06:03:04
回答 3查看 835关注 0票数 1

为了清理和分解难看的视图,我想做以下几件事:

1)在视图中:

代码语言:javascript
复制
= document_left_container do
 = document_information

2)在我的助手中:

代码语言:javascript
复制
  def document_left_container(&block)
    render partial: "/document_left_container", locals: { custom_block: block }
  end

   def document_information
    render partial: "document_information"
  end

3)部分:

对于document_left_container:

代码语言:javascript
复制
.foo
  = custom_block.call

对于document_information:

代码语言:javascript
复制
.bar

4)预期结果:

代码语言:javascript
复制
<div class='foo'>
  <div class='bar'>
  </div> 
</div>

5)实际结果:

代码语言:javascript
复制
<div class='foo'>
</div>
<div class='bar'>
</div>

有人知道我该怎么做才能让我的东西正常工作吗?

提前谢谢你,

EN

回答 3

Stack Overflow用户

发布于 2012-07-13 10:33:44

下面是我保持干燥的方法:

代码语言:javascript
复制
=content_for(:document_information) do
  .bar

.foo
  =yield(:document_information)

这将产生

代码语言:javascript
复制
<div class='foo'>
  <div class='bar'>
  </div> 
</div>
票数 1
EN

Stack Overflow用户

发布于 2012-07-13 15:39:04

我目前的解决方案是:

帮助者:

代码语言:javascript
复制
def document_left_container(&block)
  content_for :document_left_container do
    block.call
  end
  render partial: "/document_left_container"
end

部分:

代码语言:javascript
复制
.foo
  = yield :document_left_container

Rest保持不变,我真的想保持相同的结构。

我仍然很想知道为什么我的原始代码失败了。

票数 0
EN

Stack Overflow用户

发布于 2012-07-14 02:40:27

我认为你的原始代码失败了,因为你本质上是先调用render,然后再调用render。所以你把一些东西推到堆栈上,然后再把其他东西推到堆栈上。如果你这样做了,我想它会起作用的。(尽管我还没有测试过它。)

代码语言:javascript
复制
def document_left_container(&block)
  capture_haml do 
    render partial: "/document_left_container", locals: { custom_block: block }
  end
end

 def document_information
  render partial: "document_information"
end
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11461395

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档