JavaScript & HTML/JavaScript
Ajax 배열, 리스트 데이터 넘기기 (jQuery)
husks
2019. 5. 7. 17:43
반응형
Ajax로 배열 또는 값을 넘기는 예제 입니다.
Spring으로 예제를 만들었습니다.
체크박스에 선택된 값을 배열에 넣고 Ajax로 넘기는 예제 입니다.
<!DOCTYPE html>
<html>
<head>
<title>Fruit</title>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.11.3.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#save").click(function() {
//배열 선언
var fruitArray = [];
$('input[name="fruit"]:checked').each(function(i){//체크된 리스트 저장
fruitArray.push($(this).val());
});
var objParams = {
"user" : $("#user").val(), //유저 저장
"fruitList" : fruitArray //과일배열 저장
};
//ajax 호출
$.ajax({
url : "/checkTest/save",
dataType : "json",
contentType : "application/x-www-form-urlencoded; charset=UTF-8",
type : "post",
data : objParams,
success : function(retVal){
if(retVal.code == "OK") {
alert(retVal.message);
} else {
alert(retVal.message);
}
},
error : function(request, status, error){
console.log("AJAX_ERROR");
}
});
})
});
</script>
</head>
<body>
<table border="1">
<tr>
<td>
<input type="checkbox" name="fruit" value="apple">
</td>
<td>
apple
</td>
</tr>
<tr>
<td>
<input type="checkbox" name="fruit" value="banana">
</td>
<td>
banana
</td>
</tr>
<tr>
<td>
<input type="checkbox" name="fruit" value="peach">
</td>
<td>
peach
</td>
</tr>
</table>
<br>
<input type="text" id="user" value="huskdoll">
<button type="button" id="save">SAVE</button>
</body>
</html>
checkTestSave 메소드의 매개변수를 확인 하시기 바랍니다.
반응형
받은값을 System.out.println(); 로 출력해보았습니다.
fruitList ==> @RequestParam(value="fruitList[]") List<String> fruitList
user ==> @RequestParam(value="user") String user
위과 같이 jsp에서 Ajax로 넘어온 값을 Controller에서 받으면 됩니다.
package com.spring.myapp.controller;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class TestController {
//게시글 리스트 조회
@RequestMapping(value = "/checkTest")
public String checkTest(@RequestParam Map<String, Object> paramMap, Model model) {
return "checkTest";
}
//AJAX 호출 (게시글 등록, 수정)
@RequestMapping(value="/checkTest/save", method=RequestMethod.POST)
@ResponseBody
public Object checkTestSave(
@RequestParam(value="fruitList[]") List<String> fruitList,
@RequestParam(value="user") String user
) {
System.out.println("=user=");
System.out.println(user);
System.out.println("=fruit=");
for(String fruit : fruitList) {
System.out.println(fruit);
}
//리턴값
Map<String, Object> retVal = new HashMap<String, Object>();
//성공했다고 처리
retVal.put("code", "OK");
retVal.put("message", "등록에 성공 하였습니다.");
return retVal;
}
}
[예제화면]
반응형