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


当前回答

你必须使用$("#formId").submit()。

您通常会在函数中调用它。

例如:

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

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

你可以在Jquery网站上获得更多信息。

其他回答

你可以这样使用它:

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

OR

document.formName.submit();

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

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

当你有一个现有的表单,现在应该使用jquery - ajax/post现在你可以:

hang onto the submit - event of your form prevent default functionality of submit do your own stuff $(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'];

的信息 如果有人使用

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

不是这样的吗

<button name = "submit">

我花了很长时间才发现submit()不能像这样工作。

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

使用以下代码在不需要知道ID的情况下提交表单:

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

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

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