我如何阻止一个表单提交使用jquery?

我尝试了所有的方法——看看下面我尝试过的3种不同的方法,但都不起作用:

    $(document).ready(function() { 

            //option A
            $("#form").submit(function(e){
                e.preventDefault();
            });

            //option B
            $("#form").submit(function(e){
                stopEvent(e);
            });

            //option C
            $("#form").submit(function(){
                return false;
            });
    });

会有什么问题呢?

更新-这是我的html:

    <form id="form" class="form" action="page2.php" method="post"> 
       <!-- tags in the form -->
       <p class="class2">
           <input type="submit" value="Okay!" /> 
       </p>
    </form>

这里有什么问题吗?


有两点很突出:

有可能您的表单名称不是表单。而是指 删除#。 同样,e.r epreventdefault也是正确的JQuery语法。 / /选择一个 $(“形式”)。submit(函数(e) { e.preventDefault (); });

选项C也应该有效。B选项我不熟悉

一个完整的例子:

<html>
    <head>
        <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>

        <script type='text/javascript'>
         $(document).ready(function() {
            //option A
            $("form").submit(function(e){
                alert('submit intercepted');
                e.preventDefault(e);
            });
        });
        </script>
    </head>

    <body>
        <form action="http://google.com" method="GET">
          Search <input type='text' name='q' />
          <input type='submit'/>
        </form>
    </body>
</html>

防止默认/防止表单提交使用

e.preventDefault();

停止事件冒泡使用

e.stopPropagation();

为了防止表单提交“返回错误”也应该工作。


$('#form')查找id="form"的元素。

$('form')查找表单元素


我也有同样的问题。你试过的我也试过。然后我改变我的方法不使用jquery,而是使用“onsubmit”属性在表单标签。

<form onsubmit="thefunction(); return false;"> 

它的工作原理。

但是,当我试图只在function()中放置假返回值时,它不会阻止提交过程,所以我必须放置return false;onsubmit属性。


您的页面上可能只有很少的表单,使用$('form').submit()将此事件添加到页面上表单的第一次出现处。使用类选择器代替,或者试试这个:

$('form').each(function(){
    $(this).submit(function(e){
        e.preventDefault();
        alert('it is working!');
        return  false;
    })
}) 

或者更好的版本:

$(document).on("submit", "form", function(e){
    e.preventDefault();
    alert('it works!');
    return  false;
});

您忘记了表单id,它就工作了

$('form#form').submit(function(e){
   e.preventDefault();
   alert('prevent submit');             
});

我也遇到过同样的问题,我用这种方法解决了(虽然不优雅,但很有效):

$('#form').attr('onsubmit','return false;');

在我看来,它的优势在于,你可以在任何你想要的时候还原这种情况:

$('#form').attr('onsubmit','return true;');

当我使用<form>标签没有属性id="form",并直接在jquery中调用它的标签名称时,它与我一起工作。 你的代码在HTML文件:

<form action="page2.php" method="post">

Jquery脚本:

$(document).ready(function() {
      $('form').submit(function(evt){
          evt.preventDefault();// to stop form submitting
      });
 });

// Prevent form submission
$( "form" ).submit(function( event ) {
  event.preventDefault();
});

从这里开始:https://api.jquery.com/submit-selector/(关于提交类型的有趣页面)


将事件附加到submit元素,而不是form元素。 例如,在你的html中这样做

$('input[type=submit]').on('click', function(e) {
    e.preventDefault();
});

您可以简单地检查表单是否有效,如果是,运行提交逻辑,否则显示错误。

HTML

<form id="form" class="form" action="page2.php" method="post">
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />
    <input type="text" class="check-validity" value="" />

    <input type="submit" value="Okay!" />
</form>

Javascript

    $(document).ready(function () {
        var isFormValid = true;

        function checkFormValidity(form){
            isFormValid = true;
            $(form).find(".check-validity").each(function(){
                var fieldVal = $.trim($(this).val());
                if(!fieldVal){
                    isFormValid = false;
                }
            });
        }


        //option A
        $("#form").submit(function (e) {
            checkFormValidity("#form");
            if(isFormValid){
                alert("Submit Form Submitted!!! :D");
            }else{
                alert("Form is not valid :(");
            }
            e.preventDefault();
        });
    });

这似乎也有效,而且可能更简单:

$('#Form').on('submit',function(){
    return false;
})

使用jQuery,你可以做以下事情:

然后,使用带有submit按钮的本机表单提交事件,同时防止事件触发 检查表单Valid属性。

这可以实现如下:

HTML: <形式id = " yourForm " > <input id="submit" type="submit" value="Save"/> > < /形式 JavaScript: $(“形式”)。On ("submit",函数(e) { e.preventDefault (); If ($(this).valid()) { alert('成功! '); } });


信息是缺失如何防止表单提交,然后恢复情况,即允许表单提交以后。

这里有一个例子:

var savebtn_clicked;

$('form#commentform').submit( function(e) {
    return savebtn_clicked;
});

$('#savebtn').click( function() {
    savebtn_clicked = true;
    $('#form#commentform').submit();
});

在我的例子中,每个按钮都会触发表单。通过上面的代码,我可以控制哪个按钮允许提交表单。


防止提交表单数据后再发布。

  $("form").on("submit", function (e) {
   e.preventDefault();
   alert('Ok');
   $( this ).unbind( 'submit' ).submit(); // Release 
  });

它的工作