serialize()序列化表单元素为字符串,用于 Ajax 请求。
serializeArray()序列化表单元素为JSON数据。
具体实例如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script type="application/javascript" src="https://www.jb51.net/jquery-1.10.2.js"></script> <title>serializeArray()与serialize()</title> <script type="text/javascript"> function onClik(){ $("#results").html("serializeArray()与serialize()的区别如下:"); var data1 = $("#form1").serializeArray(); //自动将form表单封装成json $("#results").append("<br/><b>serializeArray:</b>"); $.each(data1, function(i, field){ $("#results").append(field.name+":"+field.value+" "); }); $("#results").append("<br/>"); var data2 = $("#form1").serialize(); //自动将form表单封装成json $("#results").append("<b>serialize():</b>"+data2); } </script> </head> <body> <form method="post" action=""> <p>进货人 : <label for="name"></label> <input type="text" /> </p> <p>性别: <label for="sex"></label> <select size="1"> <option value="男">男</option> <option value="女">女</option> </select> </p> <table> <tr> <td>商品名</td> <td>商品数量</td> <td>商品价格</td> </tr> <tr> <td><label for="pro_name"></label> <input type="text" /></td> <td><label for="pro_num"></label> <input type="text" /></td> <td><label for="pro_price"></label> <input type="text" /></td> </tr> <tr> <td><input type="text" /></td> <td><input type="text" /></td> <td><input type="text" /></td> </tr> </table> <p></p> <input type="button" value="提交"/> </form> </body> </html>
结果如下:
备注:file、image、button、submit、reset都不会被序列化