使用jQuery提交表单

我想使用jQuery提交表单。 有人可以提供代码,演示或示例链接吗?


#1楼

来自手册: jQuery Doc

$("form:first").submit();

#2楼

您将必须使用$("#formId").submit()

通常,您可以从函数中调用此函数。

例如:

<input type='button' value='Submit form' onClick='submitDetailsForm()' />

<script language="javascript" type="text/javascript">
    function submitDetailsForm() {
       $("#formId").submit();
    }
</script>

您可以在Jquery网站上获取更多信息。


#3楼

$("form:first").submit();

请参阅事件/提交


#4楼

您还可以使用jquery表单插件使用ajax进行提交:

http://malsup.com/jquery/form/


#5楼

这取决于您是正常提交​​表单还是通过AJAX调用提交表单。 您可以在jquery.com上找到很多信息,包括带有示例的文档。 要正常提交表单,请在该站点签出submit()方法。 对于AJAX ,有许多不同的可能性,尽管您可能想使用ajax()post()方法。 注意, post()实际上只是使用简化且受限制的接口调用ajax()方法的便捷方法。

我每天都要使用的一项重要资源,即jQuery How Works ,应该用作书签。 它具有使用jQuery的教程,左侧导航提供了访问所有文档的权限。

例子:

正常

$('form#myForm').submit();

AJAX

$('input#submitButton').click( function() {
    $.post( 'some-url', $('form#myForm').serialize(), function(data) {
         // ... do something with response from server
       },
       'json' // I expect a JSON response
    );
});

$('input#submitButton').click( function() {
    $.ajax({
        url: 'some-url',
        type: 'post',
        dataType: 'json',
        data: $('form#myForm').serialize(),
        success: function(data) {
                   // ... do something with the data...
                 }
    });
});

请注意,上面的ajax()post()方法是等效的。 您可以将其他参数添加到ajax()请求中以处理错误等。


#6楼

在jQuery中,我希望以下内容:

$("#form-id").submit()

但是再说一次,您真的不需要jQuery来执行该任务-只需使用常规JavaScript:

document.getElementById("form-id").submit()

#7楼

我还使用以下内容通过Ajax提交了一个表单(未实际提交):

  jQuery.get("process_form.php"+$("#form_id").serialize(), {}, 
    function() {
      alert("Okay!"); 
    });

#8楼

请注意,在Internet Explorer中,动态创建的表单存在问题。 这样创建的表单不会在IE(9)中提交:

var form = $('<form method="post" action="/test/Delete/">' +
             '<input type="hidden" name="id" value="' + myid + '"></form>');
$(form).submit();

要使其在IE中工作,请创建表单元素并在提交之前将其附加,如下所示:

var form = document.createElement("form");
$(form).attr("action", "/test/Delete")
       .attr("method", "post");
$(form).html('<input type="hidden" name="id" value="' + myid + '" />');
document.body.appendChild(form);
$(form).submit();
document.body.removeChild(form);

创建类似于示例1的表单,然后附加该表单将不起作用-在IE9中,它将引发JScript错误DOM Exception: HIERARCHY_REQUEST_ERR (3)

汤米W的道具@ https://stackoverflow.com/a/6694054/694325


#9楼

这将发送带有预加载器的表格:

var a=$('#yourform').serialize();
$.ajax({
    type:'post',
    url:'receiver url',
    data:a,
    beforeSend:function(){
        launchpreloader();
    },
    complete:function(){
        stopPreloader();
    },
    success:function(result){
         alert(result);
    }
});

我有一些技巧可以使表格数据发布以随机方法重新构建http://www.jackart4.com/article.html


#10楼

IE动态表格的技巧:

$('#someform').find('input,select,textarea').serialize();

#11楼

到目前为止,解决方案要求您知道表单的ID。

使用此代码提交表单,而无需知道ID:

function handleForm(field) {
    $(field).closest("form").submit();
}

例如,如果您想处理按钮的click事件,则可以使用

$("#buttonID").click(function() {
    handleForm(this);    
});

#12楼

您可以这样使用它:

  $('#formId').submit();

要么

document.formName.submit();

#13楼

当您拥有现有表单时,现在应该可以使用jquery-ajax / post现在可以:

  • 坚持提交-您的表单事件
  • 阻止提交的默认功能
  • 做你自己的东西

     $(function() { //hang on event of form with id=myform $("#myform").submit(function(e) { //prevent Default functionality e.preventDefault(); //get the action-url of the form var actionurl = e.currentTarget.action; //do your own request an handle the results $.ajax({ url: actionurl, type: 'post', dataType: 'application/json', data: $("#myform").serialize(), success: function(data) { ... do something with the data... } }); }); }); 

请注意,为了使serialize()函数在上面的示例中起作用,所有表单元素都需要定义其name属性。

表格范例:

<form id="myform" method="post" action="http://example.com/do_recieve_request">

<input type="text" size="20" value="default value" name="my_input_field">
..
.
</form>

@PtF-在此示例中,数据是使用POST提交的,因此,您可以通过以下方式访问数据

 $_POST['dataproperty1'] 

,其中dataproperty1是json中的“变量名称”。

如果您使用CodeIgniter,则此处为语法示​​例:

 $pdata = $this->input->post();
 $prop1 = $pdata['prop1'];
 $prop1 = $pdata['prop2'];

#14楼

使用它来使用jquery提交表单。 这是链接http://api.jquery.com/submit/

<form id="form" method="post" action="#">
    <input type="text" id="input">
    <input type="button" id="button" value="Submit">
</form>

<script type="text/javascript">
$(document).ready(function () {
    $( "#button" ).click(function() {
        $( "#form" ).submit();
    });
});
</script>

#15楼

请注意,如果您已经为表单安装了Submit事件侦听器,则内部调用commit()

jQuery('#<form-id>').submit( function(e){ 
    e.preventDefault();
    // maybe some validation in here
    if ( <form-is-valid> ) jQuery('#<form-id>').submit();
});

在尝试为此表单的Submit事件安装新的事件侦听器(失败)时将无法工作。 因此,您必须访问HTML元素本身(从jQquery中解包)并直接在此元素上调用commit():

    jQuery('#<form-id>').submit( function(e){ 
      e.preventDefault();
      // note the [0] array access:
      if ( <form-is-valid> ) jQuery('#<form-id>')[0].submit();
    });

#16楼

如果按钮位于表单标记之间,则我更喜欢以下版本:

$('.my-button').click(function (event) {
    var $target = $( event.target );
    $target.closest("form").submit();
});

#17楼

我的方法略有不同将按钮更改为提交按钮,然后单击

$("#submit").click(function(event) {
$(this).attr('type','submit');
$(this).click();
});

#18楼

有关信息
如果有人使用

$('#formId').submit();

不要这样

<button name = "submit">

花了好几个小时才发现我的commit()无法像这样工作。


#19楼

我建议使用通用解决方案,因此您不必为每种表单添加代码。 使用jquery表单插件(http://jquery.malsup.com/form/)并添加此代码。

$(function(){
$('form.ajax_submit').submit(function() {
    $(this).ajaxSubmit();
            //validation and other stuff
        return false; 
});

});

#20楼

 $( 'form' ).on( 'submit' , () => { // arrow function console.log( $( this ) ); // form } ); 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.0/jquery.js"></script> <form> <input type="text" value="Hello there"> <input type="submit" value="Go"> </form> 


#21楼

function  form_submit(form_id,filename){
    $.post(filename,$("#"+form_id).serialize(), function(data){
        alert(data);
    });
}

它将通过AJAX将表单数据发布到给定的文件名上。


#22楼

jQuery("a[id=atag]").click( function(){

    jQuery('#form-id').submit();      

            **OR**

    jQuery(this).parents("#form-id").submit();
});

#23楼

你可以这样做:

$('#myform').bind('submit', function(){ ... });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值