利用jQuery Form插件实现表单的ajax提交(原创)

利用jQuery Form插件实现表单的ajax提交(原创)

jQuery的设计非常优雅,其源代码亦给人以美感,利用jQuery框架写出来的js既简练又能完美跨浏览器。
jquery form插件是基于jQuery开发的一套能够利用ajax技术提交form的框架。
无论是jQuery,还是jquery form 都是老外写的。
通常的jQuery ajax提交写法如下:
 $.post("../user/user.do?d=checkPasswordOnUpdateByAjax",{old_password:old_password.val()},function(xml){
  });
其中:{old_password:old_password.val()}是挂的参数,为json串格式。如果只有几个参数,这种方法还是值得一用的,如果有几十个,从软件可维护性的角度去考虑,用这种方法实在不敢恭维。我曾经写过一个根据form的页内数据元素生成Json串的方法。但是对自己写的东西总觉得不够满意,有没有一种可以提交form数据的插件呢,google一下,输入关键字 jquery form plugin 。我很荣幸的搜到了我需要的东西,既然已经有轮子,自己发明的轮子暂时先放弃。从此我对jQuery form 的依赖及使用变得一发不可收拾。在我做的项目中大量的使用了该插件进行ajax数据提交。
把jquery form的相关文件导入页面
<script language="javaScript" src="../static/js/base/jquery.js"></script>      <!--jquery 包-->
<script language="javaScript" src="../static/js/base/jquery.form.js"></script>   <!--jquery  form包-->
且二者顺序不可以放反,因为文件是自上而下解析的。
function submitForm(){
    var form = $("form[name=MsgForm]");
    if($("input[name=user_name]").val() == null || $("input[name=user_name]").val() == ""){//这里是如果user_name为空则用ajaxform提交,否则按照传统方式提交。
        //ajax form post
        var options = {success:showResponse,resetForm:true,url:"../user/msg.do?d=sendMsgByAjax"};
        form.ajaxForm(options);
        return;
    }
    form.submit();//传统form提交
}
function showResponse(xml){//回调函数
    if(1 == xml){
        alert("信息发送成功!");
    }else{
        alert("信息发送失败!");
    }
}
注意:
xml的值1或者-1是后台用response打出来的。如下:
response.setContentType("text/html;charSet=UTF-8"); 
response.setCharacterEncoding("UTF-8"); 
PrintWriter pw = response.getWriter(); 
pw.println("1");
url就是form表单要提交到的地址,当然若不指定,会自动使用form里action的值。
success的值也是函数,就是提交表单处理完后要做的事。
附 :
jQuery1.3.2.js下载地址  http://www.javadn.com/read.php?tid-676.html
jQuery Form Plugin 下载地址: http://www.javadn.com/read.php?tid-925.html
jQuery Form Plugin api:  http://www.javadn.com/read.php?tid-670.html
jQuery 中文参考手册: http://www.javadn.com/shouce/jquery/
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值