javascript - jQuery 和 css 两步注册来自

标签 javascript jquery css

我要创建一个两步注册表单。 我有 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 分成了两个。您即将发布它们立即。您需要做的就是在跳转到第二个选项卡之前检查第一个选项卡。

请尝试;

    <!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>

关于javascript - jQuery 和 css 两步注册来自,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31919082/

相关文章:

javascript - 如果数组长度大于 1 则运行代码

javascript - 可放置元素的位置计算不正确

javascript - 更多/更少的影响

c# - 要用 CSS 标记的文本字段

javascript - 覆盖 Instaemail 弹出窗口的 CSS

javascript - 有人可以解释我应该如何正确调用这个函数吗?

javascript - three.js 中带有顶点着色器的属性会产生超出范围的顶点错误

javascript - Chart.JS 数据集标签格式不同

CSS div 标题位置

html - 使用 CSS3 隐藏和显示内容,希望隐藏状态成为默认状态