jquery.form.js免费版是一个功能强大的jQuery特效制作小插件。jquery.form.js免费版使用起来十分的方便。jquery.form.js是一款jquery插件,通过该插件,我们可以非常简单的实现表单的异步提交,并实现文件上传、进度条显示等等。
jquery.form.js基本简介
jquery.form.js是form插件,jquery.form.js免费版支持ajax表单提交和ajax文件上传。
该框架集form提交、验证和上传功能于一体。
该框架应与jquery完整版结合,否则使用min无效。
原理:使用js将form组装成ajax的url和data,原理由ajax提交,实际上完全可以自己写,但有这个框架可能更简单。
jQuery.form.js是form插件,支持ajax表单提交和ajax文件上传。下载地址APIajaxForm,增加所有必要的事件监听器,为ajax提交表格做准备。ajaxForm不能提交表格。
在一个页面上使用一个表格,但根据情况向不同的地址提交处理,即同一个表格有多个提交,或者一个表格提交不同的参数值。
必须引入jquery(或js)文件。
最好将jquery(或js)的代码放在表格下面,以确保通过id获得元素。
jquery.form.js使用方法:
一、jQuery.Form.js 插件的作用是实现Ajax提交表单。
方法:
1.formSerilize() 用于序列化表单中的数据,并将其自动整理成适合AJAX异步请求的URL地址格式。
2.clearForm() 清除表单中所有输入值的内容。
3.restForm 重置表单中所有的字段内容。即将所有表单中的字段恢复到页面加载时的默认值。
疑问:ajaxForm()与ajaxSubmit()的区别:
答案:$("#form1").ajaxForm(); 相当于以下两行:
$("#form1".submit)(function(){
$("#form1").ajaxSubmit();
return false;
}) //也就是说ajaxFrom()会自动阻止表单提交。而ajaxSubmit()不会自动阻止表单提交,想阻止表单提交,要自己return false;
技巧1:如果希望表单提交完成后不跳转,那么一行简单的代码就能够实现,几乎与不使用表单提交是一样的:
$("#MailForm").ajaxSubmit(function(message) {
alert("表单提交已成功!");
});
注意:ajaxForm()与ajaxForm()都可以没有参数或者接受1个参数。该参数既可以是一个回调函数,也可以是一个options对象。该对象功能非常强大,说明如下:
var options={
url:url, //form提交数据的地址
type:type, //form提交的方式(method:post/get)
target:target, //服务器返回的响应数据显示在元素(Id)号确定
beforeSubmit:function(), //提交前执行的回调函数
success:function(), //提交成功后执行的回调函数
dataType:null, //服务器返回数据类型
clearForm:true, //提交成功后是否清空表单中的字段值
restForm:true, //提交成功后是否重置表单中的字段值,即恢复到页面加载时的状态
timeout:6000 //设置请求时间,超过该时间后,自动退出请求,单位(毫秒)。
}
例子:
页面js代码:
<script src="jQuery.1.8.3.js" type="text/javascript"></script>
<script src="jQuery.Form.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$(":submit").click(function () {
var options = {
url: "indexAjax.aspx",
target: "#div2",
success: function () {
alert("ajax请求成功");
}
};
$("#form1").ajaxForm(options);
})
})
</script>
<div id="div1">
<form id="form1" method="get" action="#">
<p>我的名字:<input type="text" name="name" value="请输入内容" /></p>
<p>我的偶像是:<input type="radio" name="Idol" value="刘德华" />刘德华 <input type="radio" name="Idol" value="张学友" />张学友</p>
<p>我喜欢的音乐类型:<input type="checkbox" name="musictype" value="1.摇滚">摇滚 <input type="checkbox" name="musictype" value="2.轻松">轻柔 <input type="checkbox" name="musictype" value="3.爵士">爵士</p>
<p><input type="submit" value="确认" /></p>
</form>
</div>
<div id="div2">
</div>
后台:indexAjax.aspx.cs代码
protected void Page_Load(object sender, EventArgs e)
{
string strName = Request["name"];
string strIdol = Request["Idol"];
string strMusicType = Request["musictype"];
Response.Clear();
Response.Write("我的名字是:" + strName + "; 我的偶像是:" + strIdol + "; 我喜欢的音乐类型:" + strMusicType);
Response.End();
}