一個普通的表單。javascript

表單的代碼以下:html
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
-
-
- <script type="text/javascript">
-
- function addUser() {
- var form = document.forms[0];
- form.action = "${pageContext.request.contextPath}/user/addUser1";
-
-
- form.method = "post";
- form.submit();
- }
- </script>
-
- </head>
- <body>
- <form>
- <table>
- <tr>
- <td>帳號</td>
- <td>
- <input type="text" name="userName">
- </td>
- </tr>
- <tr>
- <td>密碼</td>
- <td>
- <input type="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" value="提交" onclick="addUser()">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
一、直接把表單的參數寫在Controller相應的方法的形參中java
- @RequestMapping("/addUser1")
- public String addUser1(String userName,String password) {
- System.out.println("userName is:"+userName);
- System.out.println("password is:"+password);
- return "/user/success";
- }
二、經過HttpServletRequest接收jquery
- @RequestMapping("/addUser2")
- public String addUser2(HttpServletRequest request) {
- String userName = request.getParameter("userName");
- String password = request.getParameter("password");
- System.out.println("userName is:"+userName);
- System.out.println("password is:"+password);
- return "/user/success";
- }
三、經過一個bean來接收ajax
1)創建一個和表單中參數對應的bean算法
- public class User {
-
- private String userName;
-
- private String password;
-
- public String getUserName() {
- return userName;
- }
-
- public void setUserName(String userName) {
- this.userName = userName;
- }
-
- public String getPassword() {
- return password;
- }
-
- public void setPassword(String password) {
- this.password = password;
- }
- }
2)用這個bean來封裝接收的參數json
- @RequestMapping("/addUser3")
- public String addUser3(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
四、經過json數據接收數據結構
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
-
- <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
- <script type="text/javascript">
- $(document).ready(function(){
- $("#button_submit").click(function(){
- var name = $("#userName").val();
- var pass = $("#password").val();
-
-
- var user = {userName:name,password:pass};
-
- $.ajax({
- type:"POST",
- url:"${pageContext.request.contextPath}/user/addUser4",
- data:user,
- success:function(data){
- alert("成功");
- },
- error:function(e) {
- alert("出錯:"+e);
- }
- });
- });
- });
- </script>
-
- </head>
- <body>
- <form>
- <table>
- <tr>
- <td>帳號</td>
- <td>
- <input type="text" id="userName" name="userName">
- </td>
- </tr>
- <tr>
- <td>密碼</td>
- <td>
- <input type="password" id="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" id="button_submit" value="提交">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
依然能夠使用bean來接收json數據app
- @RequestMapping("/addUser4")
- public String addUser4(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }
五、使用jQuery的serializeArray() 方法序列化表單元素post
若是表單元素不少,手工拼裝成json數據很是麻煩,能夠使用jQuery提供的serializeArray()方法序列化表單元素,返回json數據結構數據。
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <title>Add User</title>
-
- <script type="text/javascript" src="${pageContext.request.contextPath}/resource/script/jquery-1.9.1.min.js"></script>
- <script type="text/javascript">
- $(document).ready(function(){
- $("#button_submit").click(function(){
-
-
- var params = $("#userForm").serializeArray();
-
-
-
-
- $.ajax({
- type:"POST",
- url:"${pageContext.request.contextPath}/user/addUser5",
- data:params,
- success:function(data){
- alert("成功");
- },
- error:function(e) {
- alert("出錯:"+e);
- }
- });
- });
- });
- </script>
-
- </head>
- <body>
- <form id="userForm">
- <table>
- <tr>
- <td>帳號</td>
- <td>
- <input type="text" id="userName" name="userName">
- </td>
- </tr>
- <tr>
- <td>密碼</td>
- <td>
- <input type="password" id="password" name="password">
- </td>
- </tr>
- <tr>
- <td> </td>
- <td>
- <input type="button" id="button_submit" value="提交">
- </td>
- </tr>
- </table>
- </form>
- </body>
- </html>
依然能夠使用bean來接收json數據:
- @RequestMapping("/addUser5")
- public String addUser5(User user) {
- System.out.println("userName is:"+user.getUserName());
- System.out.println("password is:"+user.getPassword());
- return "/user/success";
- }