首页 > 解决方案 > 在块内渲染 HTML - Ruby on Rails

问题描述

我正在尝试渲染带有部分内部块的 HTML,但唯一渲染的是最后 4 个关闭</div>元素。

这是我的代码:

<%= new_item_modal do |i| %>
<div class="modal fade" id="newItemModal" tabindex="-1" role="dialog" aria-labelledby="newItemModal" aria-hidden="true">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">New Item</h5>
        <button type="button" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body" id="new-item" style="overflow:scroll;height:500px;">
        <%= render partial: "/items/form", locals: { remote: true, item: @item, categories: @categories }%>
      </div>
    </div>
  </div>
</div>
<% end %>

我的new_item_modal功能:

def new_item_modal(&block)
   if current_location.present? && can_access("create", "items")
      @item = Item.new
      @categories = current_location.categories
      block.call
   end  
end

标签: ruby-on-railsruby

解决方案


你的第一行应该是<%= new_item_modal do |item, categories| %>,你的new_modal_item方法应该有block.call(@item, @categories). 确保重命名传递给部分的变量(例如, from @itemto item)。


推荐阅读