我将创建一个两步注册表格。
我有JavaScript验证。
但是它在第二步结束时起作用。

我做了什么?
我基本上创建了一个提交表单,用div分为两部分。

   <div id="signup">
        <form action="/" method="post">
            <div class="top-row">
                <div class="field-wrap">
                    <label>First Name<span class="req">*</span>

                    </label>
                    <input type="text" required autocomplete="off" />
                </div>
                <div class="field-wrap">
                    <label>Last Name<span class="req">*</span>

                    </label>
                    <input type="text" required autocomplete="off" />
                </div>
            </div>
            <div class="field-wrap">
                <label>Email Address<span class="req">*</span>

                </label>
                <input type="email" required autocomplete="off" />
            </div>
            <div class="field-wrap">
                <label>Set A Password<span class="req">*</span>

                </label>
                <input type="password" required autocomplete="off" />
            </div>
            <li class="tab"><a href="#step2">Step 2</a>

            </li>
    </div>

    <div id="step2" style="display: none;">
        <div class="field-wrap">
            <label>Favorite Book:<span class="req">*</span>

            </label>
            <input type="text" required autocomplete="off" />
        </div>
        <div class="field-wrap">
            <label>Interests:<span class="req">*</span>

            </label>
            <input type="text" required autocomplete="off" />
        </div>
        <button type="submit" class="button button-block" />Get Started</button>
        </form>
    </div>

我的目标是检查第一步,如果一切正常,则让用户填写第二步的表格。

就我而言,您可以跳过第一步。之后,您将在第二步看到警告。非常晚。

您可以在此处进行演示:
https://jsfiddle.net/18cpd3Lw/4/

我想部分检查步骤,但只提交一次。

最佳答案

你快到了。您已经将form分为两部分。您将立即对其进行post。您需要做的只是在跳入第二个选项卡之前先检查第一个选项卡。

请尝试;

    <!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8">
    <title>Multiple step form</title>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css">
    <script type="text/javascript" src="js/jquery-1.9.0.js"></script>
    <script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/jquery.validate/1.13.1/jquery.validate.js"></script>
    <script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/jquery.validate/1.13.1/additional-methods.js"></script>
    <style type="text/css">
        #personal_information,
        #company_information{
            display:none;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="col-lg-5">
            <form class="form-horizontal" action="" method="POST" id="myform">

                <fieldset id="account_information" class="">
                    <legend>Account information</legend>
                    <div class="form-group">
                        <label for="username" class="col-lg-4 control-label">Username</label>
                        <div class="col-lg-8">
                            <input type="text" class="form-control" id="username" name="username" placeholder="username">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="password" class="col-lg-4 control-label">Password</label>
                        <div class="col-lg-8">
                            <input type="password" class="form-control" id="password" name="password" placeholder="Password">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="conf_password" class="col-lg-4 control-label">Confirm password</label>
                        <div class="col-lg-8">
                            <input type="password" class="form-control" id="conf_password" name="conf_password" placeholder="Password">
                        </div>
                    </div>
                    <p><a class="btn btn-primary next">next</a></p>
                </fieldset>

                <fieldset id="company_information" class="">
                    <legend>Account information</legend>
                    <div class="form-group">
                        <label for="company" class="col-lg-4 control-label">Company</label>
                        <div class="col-lg-8">
                            <input type="text" class="form-control" id="company" name="company" placeholder="Company">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="url" class="col-lg-4 control-label">Website url</label>
                        <div class="col-lg-8">
                            <input type="text" class="form-control" id="url" name="url" placeholder="Website url">
                        </div>
                    </div>
                    <p><a class="btn btn-primary next">next</a></p>
                </fieldset>

                <fieldset id="personal_information" class="">
                    <legend>Personal information</legend>
                    <div class="form-group">
                        <label for="name" class="col-lg-4 control-label">Name</label>
                        <div class="col-lg-8">
                            <input type="text" class="form-control" id="name" name="name" placeholder="Name">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="email" class="col-lg-4 control-label">Email</label>
                        <div class="col-lg-8">
                            <input type="email" class="form-control" id="email" name="email" placeholder="Email">
                        </div>
                    </div>
                    <p><a class="btn btn-primary" id="previous" >Previous</a></p>
                    <p><input class="btn btn-success" type="submit" value="submit"></p>
                </fieldset>

            </form>
        </div>
    </div>

    <script type="text/javascript">
        $(document).ready(function(){

            // Custom method to validate username
            $.validator.addMethod("usernameRegex", function(value, element) {
                return this.optional(element) || /^[a-zA-Z0-9]*$/i.test(value);
            }, "Username must contain only letters, numbers");

            $(".next").click(function(){
                var form = $("#myform");
                form.validate({
                    errorElement: 'span',
                    errorClass: 'help-block',
                    highlight: function(element, errorClass, validClass) {
                        $(element).closest('.form-group').addClass("has-error");
                    },
                    unhighlight: function(element, errorClass, validClass) {
                        $(element).closest('.form-group').removeClass("has-error");
                    },
                    rules: {
                        username: {
                            required: true,
                            usernameRegex: true,
                            minlength: 6,
                        },
                        password : {
                            required: true,
                        },
                        conf_password : {
                            required: true,
                            equalTo: '#password',
                        },
                        company:{
                            required: true,
                        },
                        url:{
                            required: true,
                        },
                        name: {
                            required: true,
                            minlength: 3,
                        },
                        email: {
                            required: true,
                            minlength: 3,
                        },

                    },
                    messages: {
                        username: {
                            required: "Username required",
                        },
                        password : {
                            required: "Password required",
                        },
                        conf_password : {
                            required: "Password required",
                            equalTo: "Password don't match",
                        },
                        name: {
                            required: "Name required",
                        },
                        email: {
                            required: "Email required",
                        },
                    }
                });
                if (form.valid() === true){
                    if ($('#account_information').is(":visible")){
                        current_fs = $('#account_information');
                        next_fs = $('#company_information');
                    }else if($('#company_information').is(":visible")){
                        current_fs = $('#company_information');
                        next_fs = $('#personal_information');
                    }

                    next_fs.show();
                    current_fs.hide();
                }
            });

            $('#previous').click(function(){
                if($('#company_information').is(":visible")){
                    current_fs = $('#company_information');
                    next_fs = $('#account_information');
                }else if ($('#personal_information').is(":visible")){
                    current_fs = $('#personal_information');
                    next_fs = $('#company_information');
                }
                next_fs.show();
                current_fs.hide();
            });

        });
    </script>
</body>
</html>

10-07 13:23