我在询问是否使用带有 Rails 表单助手的 Twitter Bootstrap 模式窗口并显示表单验证错误消息。我正在使用带有 Rails 3.2 的 Twitter Bootstrap 2.0。
我在 Twitter Bootstrap 模式窗口中有一个表单。页面上有一个按钮可以打开模式窗口并显示表单。一切都很好,除了当表单提交错误时,页面显示并且看不到错误消息,因为表单位于(最初未显示的)模式窗口内。
我需要使用 jQuery 来测试表单是否包含 Rails 错误消息并覆盖“display: none;” 呈现页面时的样式(或切换模式窗口以显示)。
我尝试将以下代码添加到我的 assets/javascripts/application.js 文件中,但它不起作用:
$('document').ready(function() {
if ($('#error_explanation').length > 0) {
$("#request_invite").css("display", "block");
}
})
并且:
$('document').ready(function() {
if ($('#error_explanation').length > 0) {
$("#request_invite").modal('toggle');
}
})
当出现错误消息时,我需要做什么来显示模式窗口或将其打开?
下面是在 Twitter Bootstrap 模式窗口 (Haml) 中显示表单的代码:
#request-invite.modal{:style => "display: none;"}
= form_for(resource, :as => resource_name, :url => registration_path(resource_name)) do |f|
.modal-header
%a.close{"data-dismiss" => "modal"} ×
%h3 Request Invitation
.modal-body
- if @user.errors.any?
#error_explanation
%ul
- @user.errors.full_messages.each do |msg|
%li= msg
%p
= f.label :email
%br/
= f.email_field :email
.modal-footer
= f.submit "Request Invitation", :class => "btn.btn-success"
%a.btn{"data-dismiss" => "modal", :href => "#"} Close
#romance-copy{:style => "text-align: center; margin-top: 100px"}
%h2 Want in?
#call-to-action{:style => "text-align: center; margin-top: 100px"}
%a.btn.btn-primary.btn-large{"data-toggle" => "modal", :href => "#request-invite"} Request invite