Html表单提交按钮未调用successs方法

Html form submit button not calling succes method?

本文关键字:successs 方法 调用 表单提交 按钮 Html      更新时间:2023-09-26

Html形式:

<form class="form-horizontal" id="contactfrm" onsubmit="contactus()">
<fieldset class="scheduler-border">
<!-- Form Name -->
<legend class="scheduler-border">Fill contact details</legend>
<!-- Text input-->
<div class="form-group">
<label class="col-md-4 control-label" for="fname">First Name</label>  
<div class="col-md-6"><input id="fname" name="firstName" type="text" placeholder="First Name" class="form-control input-md" title="Enter your First Name" required="required"></div>
</div>
<!-- Text input-->
<div class="form-group">
 <label class="col-md-4 control-label" for="lname">Last Name</label>  
<div class="col-md-6"><input id="lname" name="firstName" type="text" placeholder="Last Name" class="form-control input-md" title="Enter your Last Name" required="required"></div>
</div>
<!-- Button -->
<div class="form-group">
<label class="col-md-4 control-label" for="button"></label>
<div class="col-md-4">
                   <button type="submit" value="Submit" class="btn btn-success" id="submit" />
</div>
</div>
</fieldset>
 </form>

脚本代码:

<script type="text/javascript"> 
   function contactus(){
    alert("hi");
    var test = JSON.stringify({
       "help": $('#help').val(),    
       "firstName": $('#fname').val(), 
       "lastName":$('#lname').val()
       });
    alert("test values are"+test);
       $.ajax({
           type: "POST",
           contentType: 'application/json',
           url: baseurl+"contact/add",
           data: test,
           dataType:"text",
           success:successmethod,
           error: function(data,status) 
           {
            alert("Error  "+status);
           }
       });
   }
   function successmethod(data){
    document.getElementById("contactfrm").reset();
    $('#showcontactmessage').show();
    alert("Contact Details Saved");
   }
   </script>

锚定标签:

<a href="javascript:contactus();" class="btn btn-success">Contact us now</a>

在上面的表格中,当我使用锚标签提交表格时,一切都很好;调用函数并将值保存在数据库中,调用并执行success方法。但这里的问题是,当我使用button标记提交表单值时,值保存在databse中,但没有调用successs方法,而是调用error方法。。有什么需要帮忙的吗??

提交处理程序不会阻止表单提交。

JavaScript将运行,然后表单将立即提交。浏览器将离开当前页面并加载一个新页面,然后再获得对Ajax请求的响应。新页面上将不存在事件处理程序。

您需要阻止默认表单操作。使用90年代风格的方法,您需要从事件处理程序返回false

onsubmit="contactus(); return false;"