Вопрос по validation, javascript – Проверка радио кнопки в javascript

6

Необходимость подтверждения ввода с помощью переключателя, т. Е. Когда нажата кнопка «Отправить», а переключатели не выбраны, пользователь предупреждает пользователя «установите флажок», а если установлен переключатель, просто отправьте форму, не нуждается в предупреждении

Для этого можно использовать только HTML CSS и JavaScript, я знаю, что в jquery это в 1000 раз проще, но, к сожалению, я не могу это использовать.

И я знаю, что мой HTML-код недействителен, но если он не повлияет непосредственно на мою текущую проблему, то я рассмотрю его позже.

<form name="form1" action="#" onsubmit="return validateForm()" method="post"> 

    First time visitor?:<br/>
            <label for="s1">Yes</label>
            <input type="radio" id="1" name="yesno" value="1"/>
            <br/>
            <label for="s2">No</label>
            <input type="radio" id="1" name="yesno" value="2"/>

            <br/>       

    <input type="submit" value="Submit"><br/>
    </form>

Любые указатели очень ценятся, спасибо.

Примечание. Идентификаторы не должны начинаться с цифры. keune
@benji Пожалуйста, опубликуйте свою функцию validateForm. Ricardo Alvaro Lohmann
Вы удалили свой вопрос, чтобы переделать тот же самый из-за отрицательных комментариев к другому? Кстати, неверная разметка (например, дубликат ID)does напрямую повлиять на вашу текущую проблему. Florian Margaine

Ваш Ответ

5   ответов
16

1-е: если вы знаете, что ваш код неверен, вам следует исправить это, прежде чем что-либо делать!

Вы могли бы сделать что-то вроде этого:

function validateForm() {
    var radios = document.getElementsByName("yesno");
    var formValid = false;

    var i = 0;
    while (!formValid && i < radios.length) {
        if (radios[i].checked) formValid = true;
        i++;        
    }

    if (!formValid) alert("Must check some option!");
    return formValid;
}​

Посмотрите это в действии:http://jsfiddle.net/FhgQS/

Error: User Rate Limit Exceededif (radios[i].checked) formValid = true;Error: User Rate Limit Exceededif (radios[i].checked) { formValid = radios[i].value; }Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceededstackoverflow.com/questions/4404526/…
Error: User Rate Limit Exceeded
8

Пример полной проверки с использованием JavaScript:

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>Radio button: full validation example with javascript</title>
        <script>
            function send() {
                var genders = document.getElementsByName("gender");
                if (genders[0].checked == true) {
                    alert("Your gender is male");
                } else if (genders[1].checked == true) {
                    alert("Your gender is female");
                } else {
                    // no checked
                    var msg = '<span style="color:red;">You must select your gender!</span><br /><br />';
                    document.getElementById('msg').innerHTML = msg;
                    return false;
                }
                return true;
            }

            function reset_msg() {
                document.getElementById('msg').innerHTML = '';
            }
        </script>
    </head>
    <body>
        <form action="" method="POST">
            <label>Gender:</label>
            <br />
            <input type="radio" name="gender" value="m" onclick="reset_msg();" />Male
            <br />
            <input type="radio" name="gender" value="f" onclick="reset_msg();" />Female
            <br />
            <div id="msg"></div>
            <input type="submit" value="send>>" onclick="return send();" />
        </form>
    </body>
</html>

С Уважением,

Фернандо

добро пожаловать ;-)
за работой. спасибо .. +1 ..
0

описанным выше, вы также можете использовать решение HTML 5, отметив переключатели, как требуется в разметке. Это исключит необходимость в любом Javascript и позволит браузеру сделать всю работу за вас.

УвидетьHTML5: как использовать & quot; требуемый & quot; атрибут с "радио" поле ввода для получения дополнительной информации о том, как сделать это хорошо.

1

<form action="" method="post" name="register_form" id="register_form" enctype="multipart/form-data">

    <div class="text-input">
        <label>Gender: </label>
        <input class="form-control" type="radio" name="gender" id="male" value="male" />
        <label for="male">Male</label>
        <input class="form-control" type="radio" name="gender" id="female" value="female" />
        <label for="female">Female</label>
    </div>
    <div class="text-input" align="center">
        <input type="submit" name="register" value="Submit" onclick="return radioValidation();" />
    </div>

</form>

<script type="text/javascript">
    function radioValidation(){

        var gender = document.getElementsByName('gender');
        var genValue = false;

        for(var i=0; i<gender.length;i++){
            if(gender[i].checked == true){
                genValue = true;    
            }
        }
        if(!genValue){
            alert("Please Choose the gender");
            return false;
        }

    }
</script>

http://chandreshrana.blogspot.in/2016/11/radio-button-validation-in-javascript.html

1

You could do something like this


if (!(option[0].checked || option[1].checked)) {
    alert("Please Select Your Gender");
    return false;
}

Похожие вопросы