首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jquery.steps和验证不起作用-表单内容不可见(不可见)

jquery.steps和验证不起作用-表单内容不可见(不可见)
EN

Stack Overflow用户
提问于 2014-11-20 09:49:05
回答 2查看 6.1K关注 0票数 4

我已经问了这个问题一次,得到了一些有用的答复,标记为答案,并应用了一切。它看起来很管用,但遗憾的是,它没有成功。

问题是:不同步骤字段中的表单是空的。嗯,我不知道是否每一步都是空的,因为我不能在第一步看到和输入任何东西,因此无法进入下一步,因为验证似乎是有效的。

我不知道为什么。我坚持jquery页面上的示例:http://www.jquery-steps.com/Examples#advanced-form

完全相同的代码,但是:我的表单是空的。看起来是这样的:

我的守则是:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
    <head>
        <title>Demo</title>
        <meta charset="utf-8">
        <script src="/Scripts/jquery-2.1.1.js"></script>
        <script src="/Scripts/jquery.steps.js"></script>
        <link href="/Content/jquery.steps.css" rel="stylesheet">
    </head>

    <body>
        <form id="example-advanced-form" action="#">
            <h3>Account</h3>
            <fieldset>
                <legend>Account Information</legend>

                <label for="userName-2">User name *</label>
                <input id="userName-2" name="userName" type="text" class="required">
                <label for="password-2">Password *</label>
                <input id="password-2" name="password" type="text" class="required">
                <label for="confirm-2">Confirm Password *</label>
                <input id="confirm-2" name="confirm" type="text" class="required">
                <p>(*) Mandatory</p>
            </fieldset>

            <h3>Profile</h3>
            <fieldset>
                <legend>Profile Information</legend>

                <label for="name-2">First name *</label>
                <input id="name-2" name="name" type="text" class="required">
                <label for="surname-2">Last name *</label>
                <input id="surname-2" name="surname" type="text" class="required">
                <label for="email-2">Email *</label>
                <input id="email-2" name="email" type="text" class="required email">
                <label for="address-2">Address</label>
                <input id="address-2" name="address" type="text">
                <label for="age-2">Age (The warning step will show up if age is less than 18) *</label>
                <input id="age-2" name="age" type="text" class="required number">
                <p>(*) Mandatory</p>
            </fieldset>

            <h3>Warning</h3>
            <fieldset>
                <legend>You are to young</legend>

                <p>Please go away ;-)</p>
            </fieldset>

            <h3>Finish</h3>
            <fieldset>
                <legend>Terms and Conditions</legend>

                <input id="acceptTerms-2" name="acceptTerms" type="checkbox" class="required"> <label for="acceptTerms-2">I agree with the Terms and Conditions.</label>
            </fieldset>
            </form>
        </body>

    <script>
        var form = $("#example-advanced-form").show();

        form.steps({
            headerTag: "h3",
            bodyTag: "fieldset",
            transitionEffect: "slideLeft",
            onStepChanging: function (event, currentIndex, newIndex) {
                // Allways allow previous action even if the current form is not valid!
                if (currentIndex > newIndex) {
                    return true;
                }
                // Forbid next action on "Warning" step if the user is to young
                if (newIndex === 3 && Number($("#age-2").val()) < 18) {
                    return false;
                }
                // Needed in some cases if the user went back (clean up)
                if (currentIndex < newIndex) {
                    // To remove error styles
                    form.find(".body:eq(" + newIndex + ") label.error").remove();
                    form.find(".body:eq(" + newIndex + ") .error").removeClass("error");
                }
                form.validate().settings.ignore = ":disabled,:hidden";
                return form.valid();
            },
            onStepChanged: function (event, currentIndex, priorIndex) {
                // Used to skip the "Warning" step if the user is old enough.
                if (currentIndex === 2 && Number($("#age-2").val()) >= 18) {
                    form.steps("next");
                }
                // Used to skip the "Warning" step if the user is old enough and wants to the previous step.
                if (currentIndex === 2 && priorIndex === 3) {
                    form.steps("previous");
                }
            },
            onFinishing: function (event, currentIndex) {
                form.validate().settings.ignore = ":disabled";
                return form.valid();
            },
            onFinished: function (event, currentIndex) {
                alert("Submitted!");
            }
        }).validate({
            errorPlacement: function errorPlacement(error, element) { element.before(error); },
            rules: {
                confirm: {
                    equalTo: "#password-2"
                }
            }
        });
     </script>

</html>

有人能帮忙吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-11-20 13:24:07

.content似乎没有任何宽度(请看上一张截图右上角的工具提示)。给它一些宽度:

代码语言:javascript
复制
.wizard > .content {
    ...
    width: 100%;
}
票数 5
EN

Stack Overflow用户

发布于 2015-05-12 11:04:53

我已经包含了以下的CSS文件的原始Github源代码:

代码语言:javascript
复制
<link rel="stylesheet" href="css/normalize.css">
<link rel="stylesheet" href="css/main.css">

并在Chrome和IE中显示表单。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27036392

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档