Я работаю с Rails 5 и Materialize-Sass , и у меня возникают некоторые проблемы с поведением по умолчанию из Rails для обработки неудачных проверок полей, как на рисунке ниже, и это было из-за дополнительных div
добавлено в поля ввода, где проверка не удалась.
Работа с ответом @Phobetron и изменение ответа Уго Демильо тоже. Я внес некоторые коррективы в эти блоки кода, и что-то работает хорошо в следующих случаях:
- Если у
input
и label
есть свой собственный атрибут class
в любом месте
<input type="my-field" class="control">
<label class="active" for="...">My field</label>
- Если теги
input
или label
не имеют атрибута class
<input type="my-field">
<label for="...">My field</label>
- , если тег
label
имеет другой тег внутри с class attribute
<label for="..."><i class="icon-name"></i>My field</label>
Во всех этих случаях класс error
будет добавлен к существующим классам в атрибуте class
, если он существует, или будет создан, если его нет в метке или . введите тегов.
ActionView::Base.field_error_proc = Proc.new do |html_tag, instance|
class_attr_index = html_tag.index('class="')
first_tag_end_index = html_tag.index('>')
# Just to inspect variables in the console
puts '? ' * 50
pp(html_tag)
pp(class_attr_index)
pp(first_tag_end_index)
if class_attr_index.nil? || class_attr_index > first_tag_end_index
html_tag.insert(first_tag_end_index, ' class="error"')
else
html_tag.insert(class_attr_index + 7, 'error ')
end
# Just to see resulting tag in the console
pp(html_tag)
end
Надеюсь, это может пригодиться кому-то с такими же условиями, как я.