Как показать сообщения об ошибках рядом с полем - PullRequest
28 голосов
/ 13 апреля 2011

У меня есть форма с полями ввода / метками и т. Д. Как получить сообщение об ошибке рядом с полем? а не слиплись наверху?

Я использую устройство, рельсы 3

У меня есть это в верхней части моей формы:

 = form_for(resource, :as => resource_name, :url => registration_path(resource_name)) do |f|
- if resource.errors.any?
  #errorExplanation
    %h2
      = pluralize(resource.errors.count, "error")
      prevented this user from being saved:
    %ul
      - resource.errors.full_messages.each do |msg|
        %li
          = msg

Ответы [ 4 ]

36 голосов
/ 13 апреля 2011

Вы можете использовать эту

- if @resource.errors[:field_name]
  ...

Также полезную ссылку:

http://guides.rubyonrails.org/active_record_validations.html#working-with-validation-errors

6 голосов
/ 18 мая 2016

Просто создайте файл в папке инициализаторов.

config / initializers / inline_errors.rb

Поместите в него этот код:

ActionView::Base.field_error_proc = Proc.new do |html_tag, instance|
  unless html_tag =~ /^<label/
    %{<div class="has-error">#{html_tag}<span class="help-block">#{instance.error_message.first}</span></div>}.html_safe
  else
    %{#{html_tag}}.html_safe
  end
end

PD: Извините за мой английский.

4 голосов
/ 12 августа 2016

Как насчет

, если вы хотите поместить сообщение об ошибке прямо под текстовым полем, вы можете сделать это следующим образом:

.row.spacer20top
  .col-sm-6.form-group
    = f.label :first_name, "*Your First Name:"
    = f.text_field :first_name, :required => true, class: "form-control"
    = f.error_message_for(:first_name)

Что такое error_message_for?
-> Ну, это прекрасный взлом, чтобы сделать что-то классное

# Author Shiva Bhusal
# Aug 2016
# in config/initializers/modify_rails_form_builder.rb
# This will add a new method in the `f` object available in Rails forms
class ActionView::Helpers::FormBuilder
  def error_message_for(field_name)
    if self.object.errors[field_name].present?
      model_name              = self.object.class.name.downcase
      id_of_element           = "error_#{model_name}_#{field_name}"
      target_elem_id          = "#{model_name}_#{field_name}"
      class_name              = 'signup-error alert alert-danger'
      error_declaration_class = 'has-signup-error'

      "<div id=\"#{id_of_element}\" for=\"#{target_elem_id}\" class=\"#{class_name}\">"\
      "#{self.object.errors[field_name].join(', ')}"\
      "</div>"\
      "<!-- Later JavaScript to add class to the parent element -->"\
      "<script>"\
          "document.onreadystatechange = function(){"\
            "$('##{id_of_element}').parent()"\
            ".addClass('#{error_declaration_class}');"\
          "}"\
      "</script>".html_safe
    end
  rescue
    nil
  end
end

Результат enter image description here

Разметка, генерируемая после ошибки

<div id="error_user_first_name" for="user_first_name" class="signup-error alert alert-danger">This field is required.</div>
<script>document.onreadystatechange = function(){$('#error_user_first_name').parent().addClass('has-signup-error');}</script>

Соответствующий SCSS

  .has-signup-error{
    .signup-error{
      background: transparent;
      color: $brand-danger;
      border: none;
    }

    input, select{
      background-color: $bg-danger;
      border-color: $brand-danger;
      color: $gray-base;
      font-weight: 500;
    }

    &.checkbox{
      label{
        &:before{
          background-color: $bg-danger;
          border-color: $brand-danger;
        }
      }
    }

Примечание: здесь используются переменные начальной загрузки и не забудьте Перезапустить сервер сейчас и после любого изменения файла в config dir.

0 голосов
/ 13 апреля 2011

Вы можете использовать error_message_on http://apidock.com/rails/ActionView/Helpers/ActiveRecordHelper/error_message_on

Обновление:

form.error_messages был удален из Rails и теперь доступен как плагин.Пожалуйста, установите его с rails plugin install git://github.com/rails/dynamic_form.git.

...