Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: jQuery. Выключать кнопку, если в полях есть атрибут required

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
dropoff
Отправлено: 25 Марта, 2013 - 10:50:49
Post Id



Посетитель


Покинул форум
Сообщений всего: 310
Дата рег-ции: Дек. 2010  


Помог: 0 раз(а)




Доброго времени суток.

Ребята, такой вопрос.

Есть форма с заранее неизвестным количеством полей.
У полей которые обязательно заполнять или что-то выбирать, добавляется атрибут required(можно и класс добавить в принципе).
так вот. Нужно выключать кнопку Сохранения, если не заполнены эти поля.
При этом, как писал выше, количество полей заранее не известно.

Либо можно просто не выключать кнопку, а выделять поля которые пользователь пропустил, добавляя определенный класс к ник, но при этом не выполнять событие кнопки, чтобы форма не отправлялась.
Т.е. нужно проверять заполненность поле у которых есть атрибут required, либо класс с таким названием.

Могу получить ID формы, класс кнопки на которой висит событие сохранения(ajax)

Буду благодарен за помощь и советы.

(Отредактировано автором: 25 Марта, 2013 - 10:51:12)

 
 Top
armancho7777777 Супермодератор
Отправлено: 25 Марта, 2013 - 11:03:56
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Как-то так ...


Вариант с неактивной кнопкой:
CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. var requiredFields = $('[required="required"]'),
  3.     requiredFieldsSize = requiredFields.size(),
  4.     isRequiredFieldsSize = 0,
  5.     submit = $(':submit');
  6.        
  7. requiredFields.blur(function(e) {
  8.        
  9.     if($.trim(this.value) != '')
  10.     isRequiredFieldsSize++;
  11.        
  12. }).focus(function(e) {
  13.        
  14.     if(isRequiredFieldsSize == requiredFieldsSize - 1)
  15.     submit.attr('disabled', false);
  16.        
  17. });
  18.  


Вариант с добавлением класса пустым обязательным полям при попытке отправки формы:
CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. var requiredFields = $('input[required="required"]'),
  3.     requiredFieldsSize = requiredFields.size(),
  4.     isRequiredFieldsSize = 0,
  5.     submit = $(':submit');
  6.        
  7. requiredFields.focus(function(e) {
  8.     $(this).removeClass('error');
  9.     submit.attr('disabled', false);
  10. });
  11.  
  12. submit.mousedown(function(){
  13.        
  14.         requiredFields.each(function() {
  15.        
  16.                 if($.trim(this.value) != '')
  17.                 isRequiredFieldsSize++;
  18.                 else
  19.                 $(this).addClass('error');
  20.  
  21.         }); // requiredFields.each
  22.  
  23.         if(isRequiredFieldsSize < requiredFieldsSize)
  24.         {
  25.                 alert('Заполнены не все обязательные поля!');
  26.                 $(this).attr('disabled', true);
  27.                 return false;
  28.         }
  29. });
  30.  
 
 Top
dropoff
Отправлено: 26 Марта, 2013 - 10:46:33
Post Id



Посетитель


Покинул форум
Сообщений всего: 310
Дата рег-ции: Дек. 2010  


Помог: 0 раз(а)




Спасибо большое! Получилось.
А то получалось, что полей много, часть нужна обязательных... Каждое отдельно проверять сложно.
 
 Top
armancho7777777 Супермодератор
Отправлено: 26 Марта, 2013 - 11:54:12
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




Не за что.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« JavaScript & VBScript »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB