JQuery serialize
JQuery Ajax로 호출하기 전에 serialize를 해주면 form안에 값들을
한 번에 전송 가능한 data로 만들 수 있어 많은 data를 보낼 때 유용하다.
(Ajax가 아닌 다른 상황에서도 사용할 수 있음.)
형태: $("form id 또는 name").serialize();
serialize를 사용하지 않는다면 하나씩 담아줘야 하기 때문에
보낼 data가 많을수록 노가다를 엄청 해야 된다.
예제 소스
예제 소스를 통해 살펴보면, id="food" 인 form이 있다고 가능하자.
이제 아래 form을 Ajax를 사용하여 서버로 보내기 위한 data 형태로 만들어본다.
1
2
3
4
5
6
|
<form id="food">
<input type="hidden" id="ramyun" value="good" />
<input type="hidden" id="pizza" value="nice" />
<input type="hidden" id="kimchi" value="good" />
<input type="hidden" id="dogfood" value="nope" />
</form>
|
cs |
1. serialize 사용할 경우
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script>
$.ajax({
type: "",
url : 서버url,
type : "POST",
data : $("#food").serialize(),
dataType: "json"
success : function(){
alert("성공했네?!");
}
});
</script>
|
cs |
2. serialize 사용 안 할 경우
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<script>
$.ajax({
type : "POST",
url : 서버url,
data : {
ramyun: 'good',
pizza: 'nice',
kimchi: 'good',
dogfood: 'nope'
},
dataType: "json"
success : function(){
alert("성공했네?!");
}
});
</script>
|
cs |
위 케이스는 데이터 수가 적기 때문에 큰 차이가 없을 수도 있으나
보통 업무를 하다보면 전송 데이터만 수십개는 되기 때문에 유용하게 사용될 수 있다 :)
굿굿!
'[개발] Programming > JQuery' 카테고리의 다른 글
jQuery mouseover 이벤트 - 마우스 커서를 올리면 인식하기 (0) | 2021.08.01 |
---|---|
JQuery, 서로 다른 태그를 하나의 click event에 바인딩 하기 (0) | 2018.10.29 |
JQuery, visible(not hidden) elements 개수 구하기 (0) | 2018.10.29 |
[JQuery] 체크박스 개수와 체크된 체크박스 개수 구하는 방법 (0) | 2018.10.29 |
JQuery 클릭 이벤트 on("click") 과 click() 의 차이 (8) | 2018.10.29 |