0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 11

Проверка инпутов

16.08.2018, 23:05. Показов 2291. Ответов 4

Студворк — интернет-сервис помощи студентам
Нужно проверить серию из 4 инпутов, из которых данные затем будут переноситься в отдельный блок после нажатия кнопки:
1. должны вводиться только русские буквы;
2. кнопка по умолчанию disabled;
3. при заполнении хотя бы одного инпута кнопка разблокируется;
4. не обязательно заполнять все 4 инпута для отправки данных.

Пытался составить цикл через функцию, ничего не работает. Если обращаюсь к каждому отдельному инпуту через id, то работает, но это не удобно.

HTML5
1
2
3
4
5
6
<div class="input-wrap">Введите данные</div>
            <input class="item" type="text" id="item1">
            <input class="item" type="text" id="item2">
            <input class="item" type="text" id="item3">
            <input class="item" type="text" id="item4">
            <button class="btn">Ввести данные</button>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
function dataCheck() {
 
        let name,
            per_name =/^[А-Я]$/i;
 
    for (let i = 0; i < item.length; i++) {
         name = item[i].value;
        
            if(!per_name.test(name) && name !='') {
                btn.disabled = false;
 
        } else {
 
        }
    }
};
goodsCheck();
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.08.2018, 23:05
Ответы с готовыми решениями:

валидность инпутов
Добрый день! у меня есть инпуты, и мне нужно свалидировать их на пустоту используя blur и focus. Каждому инпуту я вешаю обработчики, и я...

JSON из инпутов
Всем привет, ребята.. я новенький в изучении JS, ну если быть точнее jquery. Подскажите плиз, как из вложенных инпутов собрать json. Вот...

Проверка инпутов и textarea
Есть тест с вопросами. Они выводятся списком, в каждом вопросе есть несколько вариантов ответов. На данный момент возможно выбрать только...

4
Модератор
 Аватар для Curry
5158 / 3496 / 536
Регистрация: 01.06.2013
Сообщений: 7,595
Записей в блоге: 9
17.08.2018, 00:01
Можно по id-ам так перебирать
JavaScript
1
2
3
4
    for(let i=1; i<4; i++){
        let e=document.getElementById("item"+i)
        alert(e.value);
    }
К тому же у вас вначале dataCheck, а вызывается goodsCheck - возможно, ошибка или вы привели отдельные куски кода.
0
0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 11
18.08.2018, 01:55  [ТС]
Есть блок из 4 инпутов и неактивная кнопка. Нужно, чтобы при заполнении хотя бы одного инпута и наличия дополнительного условия (mainList.open === true) кнопка активировалась. Если дополнительное условие не соблюдается или все инпуты становятся пустыми, то кнопка снова дезактивируется. Попробовал через цикл с обработчиком событий onchange, но он работает неправильно.


JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
function validate() {
  let goodsItem = document.getElementsByClassName('goods-item');
    for (let i = 0; i < goodsItem.length; i++) {
        goodsItem[i].onchange = function() {
        
            if(mainList.open === true && goodsItem[i].value.length >= 1) {
                console.log('Заполнено');
                btnApprove.disabled = false;
            } else if (!goodsItem[0].value.length < 1 && !goodsItem[1].value.length < 1  && !goodsItem[2].value.length < 1 && !goodsItem[3].value.length < 1) {
                btnApprove.disabled = true;
                console.log('Пусто');
             }
        };
 
    }
};
validate();
 Комментарий модератора 

Правила форума

4. Порядок создания тем.
4.13 Если на ваш вопрос долгое время нет ответа, уточните его, приведите дополнительные сведения, которые могут помочь участникам форума решить вашу проблему.
4.14 Чтобы "поднять" тему в разделе и поиске по форуму, используйте осмысленные сообщения, например "Тема/проблема/задача актуальна". Если вы чего-то достигли в решении проблемы на этот момент, сообщите об этом.

5. Запреты и ограничения.
5.5 Запрещено размещать тему в нескольких подразделах одного раздела одновременно (кросспостинг), а также дублировать тему в одном разделе.
0
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
18.08.2018, 02:36
dvv1979,
Зачем плодить темы? Даже не знаю отвечать вам или нет- в прошлой теме вы побоялись ответить в теме?
Вот вам проверка на пустоту:
HTML5
1
2
3
4
5
6
7
8
<div class="input-wrap">Введите данные</div>
 
<input class="item" type="text" id="item1" placeholder="№1">
<input class="item" type="text" id="item2" placeholder="№2">
<input class="item" type="text" id="item3" placeholder="№3">
<input class="item" type="text" id="item4" placeholder="№4">
 
<button class="btn" disabled="disabled">Ввести данные</button>
JavaScript
1
2
3
4
5
6
7
8
9
10
dataCheck();
function dataCheck() {
    var item = document.querySelectorAll('.item'), btn = document.querySelectorAll('.btn')[0], str;
    [...item].map((e,i)=>{
        e.addEventListener('keyup',()=> {
            str = '', [...item].map((e,i)=> str += e.value );
            str !== '' ? btn.disabled = false : btn.disabled = true;
        });
    });
}
Смотрим здеся

Условие то сможете сами добавить?
0
0 / 0 / 0
Регистрация: 15.11.2012
Сообщений: 11
18.08.2018, 07:37  [ТС]
Я не побоялся. Просто учу JS, стараюсь, в первую очередь сам думать, и только потом просить помощи на стороне, но получается не всегда. Сразу сдаваться и бежать искать помощи на стороне не привык. Спасибо за подсказку!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.08.2018, 07:37
Помогаю со студенческими работами здесь

Проверка инпутов на заполненность
Здравствуйте! Ситуация такая: есть &lt;form&gt;, внутри нее несколько &lt;div&gt;, в каждом &lt;div&gt; своя группа &lt;input&gt; относящихся к данной...

Ajax и 10 инпутов
Ребята есть такой код &lt;input type=&quot;submit&quot; name=&quot;enter1&quot; value=&quot;0-9&quot; id=&quot;enter&quot; /&gt; &lt;input...

Одновременное изменение 2-х инпутов
Доброго времени суток! Не подскажите - как менять значение 1 input'а в зависимости от другого. То есть имеем форму с полем типа город...

Отследить ввод с 3-4 инпутов
Как отследить ввод информации в инпуты если их более 1 ? так не работает $(&quot;#bar_code,...

Запись с инпутов аяксом
Всем привет, подскажите как лучше записывать данные. Имеется около 20 инпутов, часть из них может быть заполнено часть нет. ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru