javascript - BootstrapValidator 未显示成功消息

标签 javascript jquery forms twitter-bootstrap bootstrapvalidator

编辑:我借用的原始代码笔是 here 。唯一的区别是在 HTML 中,我将 action=' ' (它是空白的,所有 php 代码与表单位于同一个文件中)更改为 action='mail-form.php '。这就是 JavaScript 不工作的原因吗?

我正在使用 bootstrapvalidator 对我的 php 表单进行验证。它工作得很好,但是当我提交表单时,它不会显示成功通知,而是转到表单的 action 页面。该表格有效并且电子邮件已发送。

这是我的表单声明:

<form class="well form-horizontal" action="mail-form.php" method="post"  id="contact_form">

这是 Bootstrap 验证器在我的 javascript 中调用提交表单的方法:

  $(document).ready(function() {
    $('#contact_form').bootstrapValidator({
        // To use feedback icons, ensure that you use Bootstrap v3.1.0 or later
        feedbackIcons: {
            valid: 'glyphicon glyphicon-ok',
            invalid: 'glyphicon glyphicon-remove',
            validating: 'glyphicon glyphicon-refresh'
        },
        // Removed validation rules for brevity //
       .on('success.form.bv', function(e) {
            $('#success_message').slideDown({ opacity: "show" }, "slow") // Do something ...
                $('#contact_form').data('bootstrapValidator').resetForm();

            // Prevent form submission
            e.preventDefault();

            // Get the form instance
            var $form = $(e.target);

            // Get the BootstrapValidator instance
            var bv = $form.data('bootstrapValidator');

            // Use Ajax to submit form data
            $.post($form.attr('action'), $form.serialize(), function(result) {
                console.log(result);
            }, 'json');
        });
});

当我在验证成功后提交表单时,它会将我定向到表单的action,即mail-form.php。我希望它只显示 #success-message div,如上面 JavaScript 中所述,但事实并非如此。只需打开 mail-form.php 这是一个空白页面,回显已提交的字段值(用于我的调试)。

如果有帮助,我将在此处将脚本文件添加到页面页脚中。

  ...
  </footer>
    <script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>
    <script src="js/bootstrap.min.js"></script>
    <?php if (basename($_SERVER['PHP_SELF']) == "contact.php") { ?>
      <script src="https://www.google.com/recaptcha/api.js"></script>
    <?php } ?>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-validator/0.4.5/js/bootstrapvalidator.min.js"></script>
    <script src="js/scripts.js"></script>
</body>

我总是被告知任何脚本声明都需要位于文件末尾,以便在页面完全加载之前加载它们。我不知道这是否是我遇到问题的原因(我对 jquery 很陌生)

最佳答案

添加此提交事件以防止表单在点击时提交

$('#contact_form').on('submit',function(e){
e.preventDefault();
});

或使用函数:

submitHandler: function(validator, form, submitButton) {}

参见:http://codepen.io/anon/pen/MadxaE?editors=001

关于javascript - BootstrapValidator 未显示成功消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33900448/

相关文章:

c# - 处理新表格的正确方法

javascript - 如何获取 AngularJS 中 ngRepeated 元素的当前子范围?

javascript - 如何使用 JavaScript 在另一个页面上填写表单

javascript - 使用基于类实例类型的模板

jquery - 在不重新排序的情况下向右浮动 CSS ul 导航

javascript - 无法更改 div 尺寸

javascript - 如何设置链接的动态ID?

javascript - 使用 AngularJS 将表单控件设置为未触及焦点

javascript - 在异步函数中返回等待值就是返回一个 promise

javascript - $ ('h1' ) 如何作为 jQuery 中的数组登录到 Web 控制台?