Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/50: Рейтинг темы: голосов - 50, средняя оценка - 4.86
kostys2

JS проверка form на выбранный select

26.08.2013, 12:06. Показов 9402. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Код
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
$(document).ready(function(){  
 
    $("form#contactForm").submit(function() {
        //When the form is submitted
        var elem = $("form#contactForm").children('fieldset').children('input, textarea');
        var error,foc;
 
        //Loop through each input and textarea
        elem.each(function(index){
             
            //Does this have the class "required"?
            if($(this).hasClass('required')==true){
 
                //It has the class, is it empty or still have the default value?
                if(!this.value || this.value == this.defaultValue ) {
                 
                    //Add the error class for CSS styling
                    $(this).addClass("error");
 
                    //Switch the error var to true
                    error = true;
 
                    //If this is the first required element not filled out, save the ID
                    if(!foc)foc = $(this).attr("id");
                }else{
                     
                    //If this is filled out make sure it doesn't have the error class
                    $(this).removeClass("error");
                }
            } 
        });
 
        //If error has been switched to true
        if (error){     
 
            //Focus on the first required element that hasn't been filled out.
            if(foc)$('#'+foc).css("color","#000").css("fontStyle","normal").focus();
 
            //Stop the form from submitting
            return false;
        }else{
            //Clear default values on non required elements before submit continues
            if(elem.value == this.defaultValue)
            this.value = "";
        }
    });  
});
который проверяет заполнены ли input-ы и textarea у которых class="required", если нет, он не дает отправить данные и делает активным первое незаполненное поле.
Как мне сделать что-бы он и select проверял - выбрал ли юзер другое значение, или значение осталось по дефолту.
Вот код моего select:
HTML5
1
2
3
4
5
6
7
 <label for="prof" >Выбрать:*</label>
    <select name="prof" id="prof" class="required">
   <option value="">-----------</option>
    <option value="вариант 1">вариант 1</option>
    <option value="вариант 2">вариант 2</option>
    <option value="вариант 3">вариант 3</option>
   </select>
А тут статья в которой код разжевывается.

Я добавил сюда select
JavaScript
1
2
3
4
  $("form#contactForm").submit(function() {
        //When the form is submitted
        var elem = $("form#contactForm").children('fieldset').children('input, textarea, select');
        var error,foc;
но это не спасло ситуацию.
Спасибо!

Добавлено через 17 часов 4 минуты
В 31 строку добавил обработчик select-ов, но теперь он кидает меня на заполненный первый input в форме
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
function isEmail(emailAddress) {
    var pattern = new RegExp(/^(("[\w-\s]+")|([\w-]+(?:\.[\w-]+)*)|("[\w-\s]+")([\w-]+(?:\.[\w-]+)*))(@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][0-9]\.|1[0-9]{2}\.|[0-9]{1,2}\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\]?$)/i);
    return pattern.test(emailAddress);
};
 
$(document).ready(function(){  
 
    $("form#contactForm").submit(function() {
        //When the form is submitted
         
        var email = $("input#email");
        var elem = $("form#contactForm").children('fieldset').children('input, textarea, select');
        var error,foc;
 
        //If email is filled in and the function isEmail returns true
        if(email && !isEmail(email.val())){
            email.focus();
            email.prev("label").html("<span>Please Enter A Valid Email Address</span>");
            error = true;
        }else{
            email.prev("label").html("Your Email*");
        }
 
        //Loop through each input and textarea
        elem.each(function(index){
             
            //Does this have the class "required"?
            if($(this).hasClass('required')==true){
 
                //It has the class, is it empty or still have the default value?
                if (!this.value || this.value == this.defaultValue || $(this + "option:selected").val()=='')  {
                 
                    //Add the error class for CSS styling
                    $(this).addClass("error");
 
                    //Switch the error var to true
                    error = true;
 
                    //If this is the first required element not filled out, save the ID
                    if(!foc)foc = $(this).attr("id");
                }else{
                     
                    //If this is filled out make sure it doesn't have the error class
                    $(this).removeClass("error");
                }
            } 
        });
 
        //If error has been switched to true
        if (error){     
 
            //Focus on the first required element that hasn't been filled out.
            if(foc)$('#'+foc).css("color","#000").css("fontStyle","normal").focus();
 
            //Stop the form from submitting
            return false;
    }else{
            //Clear default values on non required elements before submit continues
            if(elem.value == this.defaultValue)
            this.value = "";
        }
    });  
 
    //Remove Default Text On Focus
    $("input, textarea").focus(function() {  
        if( this.value == this.defaultValue ) {  
            this.value = "";  
            $(this).css("color","#000").css("fontStyle","normal");  
        }  
    }).blur(function() {  
        if( !this.value.length ) {                
            $(this).css("color","#999").css("fontStyle","italic");  
            this.value = this.defaultValue;  
        }  
    }); 
 
});
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.08.2013, 12:06
Ответы с готовыми решениями:

Select выбранный
Здравствуйте.У меня в админ блоке появилась такая проблема, есть поле select: &lt;p&gt;&lt;label&gt;Выберите...

Не выбранный <select>
Возник вопрос как есть 4 селекта как. Если какой то из них не выбран то есть по умолчанию стоит первый &lt;option&gt; не учитывать его и...

Найти выбранный элемент в select
добрый день Подскажите пожалуйста как найти выбранный элемент в select? var select = $(element).find('select'); // получаю весь...

1
 Аватар для Soldado
901 / 833 / 198
Регистрация: 28.06.2012
Сообщений: 1,607
Записей в блоге: 4
26.08.2013, 12:22
Укажите value, например, "0" для стартового option
Вот пример блокирования отправки если не сделан выбор
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<html>
  <head>
    <title>Блокирование отправки</title>
    
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />    
<script src="http://code.jquery.com/jquery-latest.js"></script>
    
 <script type="text/javascript">
$(document).ready(function(){
    var choiceSelect=0;
 $('#prof').change(function(){
   choiceSelect = $(this).find('option:selected').val();
});
 
// блокирование отправки если choiceSelect==0
$('#otpr').click(function(){
    if(choiceSelect==0){
        alert("Выбор не сделан!");
            }
    else{
        alert("Запускается код отправки!");
    }
    
});              
 });/*end  ready*/
 </script>
<style>
</style>    
  </head>
  <body style="padding-left:140px;">
    <select name="prof" id="prof" class="required">
   <option value="0">-----------</option>
    <option value="вариант 1">вариант 1</option>
    <option value="вариант 2">вариант 2</option>
    <option value="вариант 3">вариант 3</option>
   </select>
<input type="button" id="otpr" value="Кнопка для отправки - тест"/>    
  </body>
</html>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.08.2013, 12:22
Помогаю со студенческими работами здесь

Уловить выбранный элемент из <select>
Всем доброго времени суток!!! Уважаемые, столкнулся с проблемой. В базе данных лежит таблица с записями, и есть форма с...

Смена цвета фона страницы на выбранный цвет в select
Задание.Написать скрипт. 1 Поместите на форму несколько радиокнопок с обозначением цветов и выбор радиокнопки делает этот цвет цветом фона...

Select по значению из form
&lt;form method=&quot;post&quot;&gt; &lt;p&gt;&lt;select name=&quot;param&quot;&gt; &lt;option disabled selected value&gt;country&lt;/option&gt; &lt;option...

Spring form:select
&lt;form:select path=&quot;ошибка видимости&quot; id=&quot;login&quot; class = &quot;form-control&quot;&gt; кто нибудь работал с формами spring? В контролере при...

Вывод выбранного form select
Товарисчи, наверно мне сюда)) Вопрос настолько глупый, что никому в голову видимо не приходил, ибо в гугле не засвитился. А вопрос...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru