1、通過ajax,示例:
傳給后台的數據通過json封裝起來,再用ajax將json傳到后台,ajax是用到Jquery的ajax,在jsp先加入Jquery的引用
<script type="text/javascript" src="js/jquery-1.9.1.min.js"></script>
js傳值的方法如下
function testAjax() {
var users=[{
name:'張三',
age:'21',
birth:'1994-12-12'
},
{
name:'李四',
age:'20',
birth:'1995-12-11'
},
{
name:'wangwu',
age:'20',
birth:'1995-12-11'
}];
$.ajax({
type:'POST',
data:JSON.stringify(users),
contentType :'application/json',
dataType:'json',
url :'user/saveJsonUser.do',
success :function(data) {
alert("OK");
},
error :function(e) {
alert("error");
}})
}
后台處理:用到springmvc這里參數中要加上@RequestBody,@RequestBody將HTTP請求正文轉換為適合的HttpMessageConverter對象。
@RequestMapping(value="/saveJsonUser.do",method=RequestMethod.POST)
public Map saveJsonUser(@RequestBody User[]users){
for(Useru:users){
System.out.println(u.getName()+" "+u.getAge()+" "+u.getBirth());
}
Map result=newHashMap();
result.put("success","123");
return result;
}
2、在action中請求后台的方法。但是如果數值在傳給后台之前需要校驗,可以在form中的onsubmit調用js方法進行校驗,js方法的返回值為true時,觸發action,返回false時,action不起作用。
3、通過dom獲取標簽,觸發標簽的submit方法,直接提交數據到后台
function query() {
var inputs = document.getElementsByName("sex");//對象是單選選項
for(var i = 0; i < inputs.length; i++) {
if(inputs[i].checked) {//是否選中
var sex = inputs[i].value;
document.getElementById("query").action = projectName+"/query.do?currentPage=1&stsex="+ sex;
break;
}else{
document.getElementById("query").action = projectName+"/query.do?currentPage=1";
}
}
document.getElementById("query").submit();//提交到后台
}