使用jQuery提交表单

meh*_*hul 460 jquery

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

tva*_*son 456

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

我每天都要使用的一个关键资源是jQuery如何工作.它有关于使用jQuery的教程,左侧导航可以访问所有文档.

例子:

正常

$('form#myForm').submit();
Run Code Online (Sandbox Code Playgroud)

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...
                 }
    });
});
Run Code Online (Sandbox Code Playgroud)

请注意,上述ajax()post()方法是等效的.您可以在ajax()请求中添加其他参数来处理错误等.

  • 我错过了序列化方法.显然,我查看了jQuery.com,但他们关于`$ .post`的文档明确地解构并重构表单以生成要提交的数据.谢谢! (3认同)

Dra*_*aco 120

你将不得不使用$("#formId").submit().

你通常会在一个函数中调用它.

例如:

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

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

您可以在Jquery网站上获得有关此内容的更多信息.

  • 如果您正在使用jQuery,为什么要使用内联onclick属性? (53认同)
  • @BradleyFlood - 他应该怎么做呢?像我们这样的新手想知道吗? (3认同)
  • @MarcoZen 我认为 BradleyFlood 指出短语“例如:”意味着使用内联 onclick 属性只是几种可能的方法之一。事实上,更像 jQuery 的将使用 .on('click', submitDetailsForm)。 (2认同)

wom*_*omd 69

当你有一个现有的表单,现在应该使用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...
                    }
            });
    
        });
    
    });
    
    Run Code Online (Sandbox Code Playgroud)

请注意,为了使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>
Run Code Online (Sandbox Code Playgroud)

@PtF - 在此示例中使用POST提交数据,因此这意味着您可以通过访问您的数据

 $_POST['dataproperty1'] 
Run Code Online (Sandbox Code Playgroud)

,其中dataproperty1是json中的"变量名".

这里是使用CodeIgniter的示例语法:

 $pdata = $this->input->post();
 $prop1 = $pdata['prop1'];
 $prop1 = $pdata['prop2'];
Run Code Online (Sandbox Code Playgroud)


ger*_*erg 67

在jQuery中我更喜欢以下内容:

$("#form-id").submit()
Run Code Online (Sandbox Code Playgroud)

但话说回来,你真的不需要jQuery来执行该任务 - 只需使用常规JavaScript:

document.getElementById("form-id").submit()
Run Code Online (Sandbox Code Playgroud)


Ada*_*ane 40

从手册:jQuery Doc

$("form:first").submit();
Run Code Online (Sandbox Code Playgroud)

  • 通过"id"提交表单比找到第一个表单并提交它更好.但是如果一次只有一个表单,它将完美地运行. (2认同)

A.Z*_*oft 20


如果有人使用的信息

$('#formId').submit();
Run Code Online (Sandbox Code Playgroud)

不要使用任何

<button name = "submit">
Run Code Online (Sandbox Code Playgroud)

我花了很多时间才发现submit()不会像这样工作.

  • 关键字“sumit”的拼写错误使得不清楚该拼写错误是答案中无意的还是与问题有关。你的意思是一个名为“submit”的按钮搞乱了jquery表单submit()?或者你的意思是问题是你给了按钮_name_提交而不是标准的`type =“submit”`? (2认同)

小智 14

这将发送一个带预加载器的表单:

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

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


Chi*_*mar 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>
Run Code Online (Sandbox Code Playgroud)

  • 尽管这是一篇旧帖子,但值得在您的按钮中添加一个类型“按钮”以确保表单不会提交(因为并非所有浏览器都以相同的方式对待没有类型的按钮)。 (2认同)

小智 13

请注意,如果您已经为表单安装了一个提交事件监听器,那么提前调用submit()

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

将无法正常工作,因为它尝试为此表单的提交事件(失败)安装新的事件侦听器.因此,您必须访问HTML元素本身(从jQquery展开)并直接在此元素上调用submit():

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


Ric*_*ard 8

你也可以使用jquery表单插件使用ajax提交:

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


小智 7

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

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

            **OR**

    jQuery(this).parents("#form-id").submit();
});
Run Code Online (Sandbox Code Playgroud)


Nen*_*lep 7

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

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

要使它在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);
Run Code Online (Sandbox Code Playgroud)

像示例1中那样创建表单然后附加它将不起作用 - 在IE9中它会抛出JScript错误 DOM Exception: HIERARCHY_REQUEST_ERR (3)

汤米W的道具@ /sf/answers/468583811/


muz*_*amo 7

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

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

function handleForm(field) {
    $(field).closest("form").submit();
}
Run Code Online (Sandbox Code Playgroud)

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

$("#buttonID").click(function() {
    handleForm(this);    
});
Run Code Online (Sandbox Code Playgroud)


Tk4*_*421 6

如果按钮位于表单标签之间,我更喜欢这个版本:

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


小智 5

动态表单的 IE 技巧:

$('#someform').find('input,select,textarea').serialize();
Run Code Online (Sandbox Code Playgroud)


Ram*_*eti 5

你可以这样使用它:

  $('#formId').submit();
Run Code Online (Sandbox Code Playgroud)

或者

document.formName.submit();
Run Code Online (Sandbox Code Playgroud)


Nav*_*nDA 5

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

$("#submit").click(function (event) {
  $(this).attr("type", "submit");
  $(this).click();
});
Run Code Online (Sandbox Code Playgroud)