傳統的表單提交,都是頁面跳躍的形式,但是現在更流行ajax提交,那麼如果希望有表單提交的簡便,也有ajax的效果,有什麼解決辦法嗎?
怎麼使用
兩種使用方式:
第一種方式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="js/jquery-1.9.1.min.js"></script> <script src="js/jquery-form.js"></script> <script> // 使用ajaxForm $(function(){ $("#myForm").ajaxForm(function(){ $("#output1").html("提交成功").show(); }) }) </script> </head> <body> <form id="myForm"> <input type="text" name="username"> <input type="text" name="password"> <input type="submit" value="提交"> <div id="output1" style="display: none"></div> </form> </body> </html>
第二種方式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="js/jquery-1.9.1.min.js"></script> <script src="js/jquery-form.js"></script> <script> $(function(){ //方式二 与方式一效果一样 $("#myForm").submit(function(){ // 使用ajaxSubmit $(this).ajaxSubmit(function(){ $("#output1").html("提交成功").show(); }); return false; }) }) </script> </head> <body> <form id="myForm"> <input type="text" name="username"> <input type="text" name="password"> <input type="submit" value="提交"> <div id="output1" style="display: none"></div> </form> </body> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="js/jquery-1.9.1.min.js"></script> <script src="js/jquery-form.js"></script> <script> var options = { target:'#output1', // 把服务器返回的内容放入id为output1的元素中 beforeSubmit: fun1, // 提交前的回调函数 success: fun2, // 提交后的回调函数 dataType: // 接收服务端返回的类型 xml,scrpit,json }; // beforeSubmit前可以作验证 function fun1(formData,jqForm,options){ // formData 提交值的数组对象 // jqForm 表单元素的jQuery对象,jqForm[0]是其dom对象 // 该函数如果返回false,则阻止表单提交 // formData可以判断全部不为空的情况 for(var i=0;i<formData.length;i++){ if(!formData[i].value){ alert("都不能为空"); return false; } } // jqForm可以判断某个不为空的情况 var form = jqForm[0]; if(!form.name.value){ alert("name不能为空"); return false; } // fieldValue()可以获取多值的数组形式,如checkbox var value = $('input[name=name]').fieldValue(); if(!value[0]){ return false; } } function fun2(responseText, statusText){ // 根据dataType不同responseText解析方式不同, // 默认 responseText // xml responseXml以xml解析 // json responseJson } $(function(){ //方式二 与方式一效果一样 $("#myForm").ajaxForm(options); // 要想使options生效,需要作为参数传递 }) </script> </head> <body> <form id="myForm"> <input type="text" name="username"> <input type="text" name="password"> <input type="submit" value="提交"> <div id="output1" style="display: none"></div> </form> </body> </html>
第二種方式
rrreee
其中的參數function()是提交成功後的回呼函數。 利用這種提交方式,可以實現非同步表單提交,很方便。但是,還是有點不滿足,比如說,我可能想在提交表單之前驗證一下,雖然可以手動地在提交表單動作之外完成,但是很麻煩。 form插件有沒有繼承這樣的功能呢?
二、options參數🎜上面只講了form中的一個function回呼函數參數,其實它還有一個參數,就是options。有什麼用呢? 🎜rrreee🎜可以看出,在beforeSubmit的回呼函數fun1中,我們有三種方式取得表單資料 formData,jqForm,fieldValue 滿足了各種取得值的方式,想怎麼驗證怎麼驗證。只要回傳false就能阻止表單提交sucess回呼的fun2也有狀態值和服務端的回傳數據,想怎麼處理怎麼處理。 🎜