Angular.js前台传list数组由后台spring MVC接收数组示例代码
前言
本文主要给大家介绍了关于Angular.js前台传list数组由后台springMVC接收数组的相关内容,分享出来供大家参考学习,下面话不多说,来一起看看详细的介绍吧。
在开发中有时候需要在前台自定义对象,然后把对象封装在list中,在传送到后台,这样的思想也比较合理,直接来看示例代码:
1.前台代码
$scope.saveScore=function(){
$scope.userScoreList=newArray();//自定义数组
angular.forEach($scope.records,function(record,index){
if(record.score!=null){
$scope.userScoreModel={'userAnswerId':null,'score':null};//自定义对象结构
$scope.userScoreModel.userAnswerId=record.userAnswerId;//赋值
$scope.userScoreModel.score=record.score;
$scope.userScoreList.push($scope.userScoreModel);//把对象封装在集合中
debugger;
}
});
if($scope.userScoreList!=null&&$scope.userScoreList.length>0){
varfd=newFormData();//使用angularJS的FormData封装要传送的数据
varuserScoreRecords=angular.toJson($scope.userScoreList);//把对象(集合)转换为json串
fd.append('userScoreRecords',userScoreRecords);//参数放入formData中
debugger;//使用debugger模式查看传值情况
$http.post('/reviewProcess/save',fd,{//使用post方法传送formdata对象
transformRequest:angular.identity,//使用angular传参认证
headers:{
'Content-Type':undefined//设置请求头
}
})
.success(function(data){
toastr.success("success");
})
.error(function(data){
toastr.success("failed");
});
}
};
2.后台接收
@ResponseBody
@RequestMapping(value="/reviewProcess/save",method=RequestMethod.POST)
publicvoidsaveUserScore(@RequestParam("userScoreRecords")StringuserScoreRecords){//使用requestparam接收前台传送的json串
System.out.println(userScoreRecords);
ObjectMappermapper=newObjectMapper();//使用fastJson的ObjectMapper反序列化json串为对象
UserScoreModelrecord=null;
try{
JSONArrayjsonArray=newJSONArray(userScoreRecords);//在后台把json串转换为json数组
for(inti=0;i
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持