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

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

26.08.2013, 12:06. Показов 9375. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru