0

validates_acceptance_of :terms, :message => "must be accepted"在我的user.rb模型中使用,并且正在使用bootstrap-sass.

我的复选框代码在视图中如下所示:

<div class="control-group">
  <%= f.label :terms, :class => "control-label" do %>
    Accept <%= link_to('Terms of Use *', "#myTOUModal", :"data-toggle" => "modal") %>
  <% end %>
  <div class="controls">
    <%= f.check_box :terms %>
  </div>
</div>

出于某种原因,如果在提交表单时未选中术语复选框,则会在表单顶部显示相应的错误消息,但field_with_errorsdiv 类环绕复选框标签存在问题。

呈现页面的 HTML 如下所示:

<div class="control-group">
  <label class="control-label" for="user_terms">
    Accept <a href="#myTOUModal" data-toggle="modal">Terms of Use *</a>
  </label>
  <div class="controls">
    <input name="user[terms]" type="hidden" value="0" />
    <div class="field_with_errors">
      <input id="user_terms" name="user[terms]" type="checkbox" value="1" />
    </div>
  </div>
</div>

结果是复选框字段标签在错误时未突出显示。有没有办法强制field_with_errors类的 div 标签放置在标签之后显示<div class="control-group">?为什么使用块来定义字段标签会影响field_with_errors标签放置?有人对此有经验吗?

谢谢

4

1 回答 1

0

我认为这是一个错误。问题出在块中。无阻碍地定义您的标签,一切正常。

尝试类似:

<% modal_html = capture do >
  Accept <%= link_to('Terms of Use *', "#myTOUModal", :"data-toggle" => "modal") %>
<% end %>

<%= f.label :terms, modal_html, :class => "control-label" %>

或帮手:

def modal_html
  #Q{Accept #{link_to('Terms of Use *', "#myTOUModal", :"data-toggle" => "modal")} }.html_safe
end
于 2012-12-13T15:49:42.517 回答