我想使用jQuery提交一个表单。有人能提供代码,演示或示例链接吗?
当前回答
在jQuery我更喜欢以下:
$("#form-id").submit()
但话又说回来,你真的不需要jQuery来执行这个任务-只需使用常规的JavaScript:
document.getElementById("form-id").submit()
其他回答
这将发送一个带有预加载器的表单:
var a=$('#yourform').serialize();
$.ajax({
type:'post',
url:'receiver url',
data:a,
beforeSend:function(){
launchpreloader();
},
complete:function(){
stopPreloader();
},
success:function(result){
alert(result);
}
});
我有一些技巧,使一个表单数据post随机方法改革http://www.jackart4.com/article.html
当你有一个现有的表单,现在应该使用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'];
我还使用以下方法通过Ajax提交了一个表单(没有实际提交它):
jQuery.get("process_form.php"+$("#form_id").serialize(), {},
function() {
alert("Okay!");
});
如果按钮位于表单标签之间,我更喜欢这个版本:
$('.my-button').click(function (event) {
var $target = $( event.target );
$target.closest("form").submit();
});
注意,如果您已经为表单安装了提交事件侦听器,则内部调用submit()
jQuery('#<form-id>').submit( function(e){
e.preventDefault();
// maybe some validation in here
if ( <form-is-valid> ) jQuery('#<form-id>').submit();
});
不会工作,因为它试图为这个表单的提交事件安装一个新的事件侦听器(失败)。所以你必须访问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();
});
推荐文章
- 可以在setInterval()内部调用clearInterval()吗?
- 无法读取未定义的属性“msie”- jQuery工具
- jQuery:执行同步AJAX请求
- jQuery表格排序
- 如何禁用文本选择使用jQuery?
- 如何停止事件冒泡复选框点击
- Bootstrap抛出Uncaught错误:Bootstrap的JavaScript需要jQuery
- 如何删除和清除所有的本地存储数据
- 如何修改标签文本?
- 如何获得十六进制颜色值而不是RGB值?
- 如何将一个标题转换为jQuery的URL段塞?
- $(window).width()与媒体查询不一样
- AJAX请求中的内容类型和数据类型是什么?
- 如何打破_。在underscore.js中的每个函数
- 如何在jQuery中获得当前日期?