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();//提交到后台
}
ps:整理下工作中遇到的,歡迎大佬提出意見
1-后台接參
如果javabean里的屬性是大寫字母開頭則會出現這種問題,請求的時候,json字符串是大寫開頭,MVC在接收的時候,根據對象的setter,getter屬性認為字段都是小寫的,所以沒辦法綁定。規范代碼,屬性也應該是小定字母開頭
2-前端傳參
不傳參數,后台接收是null, 傳了不賦值,后台接是空串 所以,建議StringUtils.isNotBlank()判斷
ps:null和""的區別
null表示一個字符串對象的引用為空,String a=null; 聲明了一個字符串變量a,變量a的引用為空。所以a沒有指向任何的內存空間,在堆中也沒有開辟任何的空間
空字符串表示一個字符串對象引用的值為空,String a =“” 聲明了一個字符串變量a,變量a的值為空。而a指向了空字符串的內存空間