Проверка нескольких наборов переключателей

У меня есть форма с 29 выборами парных переключателей, каждая из которых имеет выбор «Да/Нет».

Имена выборок увеличиваются так же, как и для каждого набора: ans1, ans2, ans3 ... ans29. Каждый из них имеет значение «да» или «нет»,

Это более или менее похоже на это:

<input type="radio" id="yes1" name="ans1" value="yes"/>
<input type="radio" id="no1" name="ans1" value="no"/>

Я хочу написать функцию Javascript для проверки ответов при отправке формы. Я думал об использовании массива в цикле, но понятия не имею, как получить выделение в массив.

Очевидным длинным методом является повторяющийся if (ans1 = yes) {do something} if (ans2 = yes) {do something} . Я видел примеры getElementsByName , но не уверен, как реализовать его в простой функции цикла для проверки каждой итерации.

2
nl ja de
Как вы хотите точно проверить? Каковы правила?
добавлено автор Explosion Pills, источник
Вы пытались использовать объект вместо массива?
добавлено автор slamborne, источник
почему нет принятого ответа?
добавлено автор Johanes Matian, источник

2 ответы

Использование jQuery

$("input:radio:checked").each(function (index) {
    var this$ = $(this);
    var q = this$.attr('name');
    var a = this$.val();

    console.log('Question: ' + q + ', answer: ' + a);
});

Этот фрагмент выбирает только отмеченные радиокнопки, а затем печатает их на консоли. Вы можете делать все, что от вас требуется, q - это имя вопроса (например, ans1 ) и a - сам ответ (т.е. < code> true of false ).

См. в действии .

5
добавлено

используйте jQuery ( http://jquery.com/ ), например

for(int i = 1; i < 30; ++i)
{
    if ($('#yes' + i).val() == 'yes'){ do something }
}
1
добавлено
JavaScript Jobs — чат
JavaScript Jobs — чат
8 336 участник(ов)

JavaScript Jobs — чат для поиска работы и людей Правила оформления: https://teletype.in/@telegram-ru/r1WQe5F1m См. также: @mobile_jobs, @devops_jobs, @nodejs_jobs, @react_js, @angular_ru, @js_ru

JavaScript.ru
JavaScript.ru
7 932 участник(ов)

Сообщество сайта JavaScript.ru в Slack.

pro.js
pro.js
4 675 участник(ов)

Про JavaScript и NodeJS Invite: https://t.me/joinchat/Be4rsT5Rsgq30DHutjxXgA Правила: http://telegra.ph/ru-chat-rules-06-19 Вакансии только с ЗП, не чаще раза в неделю.

JavaScript — русскоговорящее сообщество
JavaScript — русскоговорящее сообщество
3 269 участник(ов)

Рекомендуем сразу отключить уведомления Правила: https://rudevs.network/ByaMH6un7 См. также: @js_noobs_ru, @nodejs_ru, @typescript_ru, @react_js, @electron_ru Вакансии и поиск работы: @javascript_jobs

JavaScript Noobs — сообщество новичков
JavaScript Noobs — сообщество новичков
2 484 участник(ов)

Чат для новичков

javascript_ru
javascript_ru
915 участник(ов)

Сообщество любителей самого популярного языка программирования в мире. Чат основан в 2009 году. Логи: https://goo.gl/9EOeM7 Поддержка бота: @chat_linker (ссылка на репу внутри) Вам будут интересны @frontend_ru и @css_ru

jsChat
jsChat
603 участник(ов)

Чат посвященный программированию на языке javaScript Перед отправкой ссылки на Ваш контент посоветуйтесь с админом Все ссылки удаляются ботом автоматически

JavaScript for Zombies Chat
JavaScript for Zombies Chat
492 участник(ов)

Чат про JavaScript для настоящих zombie! Вход строго по приглашениям! Ссылка для строгих приглашений: https://t.me/joinchat/AAMBHz3Uyr0tuZ7VaB029g

All That JS
All That JS
417 участник(ов)

JS на русском