关于ASP.NET MVC的Html.BeginForm()方法

关于ASP.NET MVC的Html.BeginForm()方法,第1张

这个不是MVC的问题,这是基本的HTML。

生成的表单,如果不指明目标Action的话,默认提交的地址就是当前地址。

比如有Edit,直接用Html.BeginForm(),就会提交到httpost特性的Edit控制器方法上去。

增删改查全部使用独立的控制器方法实现。

html页面通过 ajax请求的response返回 return mapper.toJson()//json字符串

然后html通过ajax返回值获取进行处理类似

Java code?

$.ajax({

url : "${pageContext.request.contextPath}/admin/wxflowMainNodeLog/view.do",

async : true,

data:data,

dataType : 'json',

type : 'GET',

success : function(rtn, textStatus) {

//业务控制

if(rtn.result == "success"){

$("#docId").val(rtn.data.docId)

$("#docSubject").val(rtn.data.docSubject)

$("#mainId").val(rtn.data.mainId)

$("#nodeId").val(rtn.data.nodeId)

$("#auditId").val(rtn.data.auditId)

$("#mediaId").val(rtn.data.mediaId)

$("#mediaUrl").val(rtn.data.mediaUrl)

$("#curActor").val(rtn.data.curActor)

$("#myModal").modal("show")

}else{

alert(rtn.message)

}

},

error : function(jqXHR, textStatus,

errorThrown) {

var sessionstatus = jqXHRgetResponseHeader("sessionstatus")

if (sessionstatus == "timeout") {

alert(i1510.sessionOutMes)

var req_address = i1510.sessionOutUrl

window.location.href = req_address

}

}

})

1、直接把表单的参数写在Controller相应的方法的形参中

@RequestMapping("/addUser1")

public String addUser1(String userName,String password) {

System.out.println("userName is:"+userName)

System.out.println("password is:"+password)

return "/user/success"

}

2、通过HttpServletRequest接收

@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"

}

3、通过一个bean来接收

1)建立一个和表单中参数对应的bean

public class User { private String userNameprivate String passwordpublic String getUserName() { return userName }

//getter,setter方法。。. }

2)用这个bean来封装接收的参数

@RequestMapping("/addUser3")

public String addUser3(User user) {

System.out.println("userName is:"+user.getUserName())

System.out.println("password is:"+user.getPassword())

return "/user/success"

}

4、通过json数据接收

<%@ page language="java" contentType="text/htmlcharset=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/htmlcharset=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}//拼装成json格式

$.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数据

@RequestMapping("/addUser4")

public String addUser4(User user) {

System.out.println("userName is:"+user.getUserName())

System.out.println("password is:"+user.getPassword())

return "/user/success"

}

5、使用jQuery的serializeArray() 方法序列化表单元素

如果表单元素很多,手工拼装成json数据非常麻烦,可以使用jQuery提供的serializeArray()方法序列化表单元素,返回json数据结构数据。 

<%@ page language="java" contentType="text/htmlcharset=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/htmlcharset=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(){

//序列化表单元素,返回json数据

var params = $("#userForm").serializeArray()

//也可以把表单之外的元素按照name value的格式存进来

//params.push({name:"hello",value:"man"})

$.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"

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6273134.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-19
下一篇 2023-03-19

发表评论

登录后才能评论

评论列表(0条)

保存