43์ฅ Ajax
Last updated
Last updated
Ajax(Asynchronous JavaScript and Xml)
์ด๋
์๋ฐ์คํฌ๋ฆฝํธ๋ฅผ ์ฌ์ฉํ์ฌ ๋ธ๋ผ์ฐ์ ๊ฐ ์๋ฒ์๊ฒ ๋น๋๊ธฐ ๋ฐฉ์์ผ๋ก ๋ฐ์ดํฐ๋ฅผ ์์ฒญํ๊ณ , ์๋ฒ๊ฐ ์๋ตํ ๋ฐ์ดํฐ๋ฅผ ์์ ํ์ฌ ์น ํ์ด์ง๋ฅผ ๋์ ์ผ๋ก ๊ฐฑ์ ํ๋ ํ๋ก๊ทธ๋๋ฐ ๋ฐฉ์์ด๋ค.
Ajax๋ ๋ธ๋ผ์ฐ์ ์์ ์ ๊ณตํ๋ WEB API์ธ XMLHttpRequest ๊ฐ์ฒด๋ฅผ ๊ธฐ๋ฐ์ผ๋ก ๋์ํ๋ค. XMLHttpRequest๋ HTTP ๋น๋๊ธฐ ํต์ ์ ์ํ ๋ฉ์๋์ ํ๋กํผํฐ๋ฅผ ์ ๊ณตํ๋ค.
๋ณ๊ฒฝ์ด ํ์ํ ๋ถ๋ถ๋ง ํ์ ์ ์ผ๋ก ๋ ๋๋ง ํ๋ ๋ฐฉ์์ด ๊ฐ๋ฅํด์ก๋ค.
์ ํต์ ๋ฐฉ์๊ณผ ๋น๊ตํ์ ๋์ Ajax ์ฅ์
๋ณ๊ฒฝํ ๋ถ๋ถ์ ๊ฐฑ์ ํ๋ ๋ฐ ํ์ํ ๋ฐ์ดํฐ๋ง ์๋ฒ๋ก๋ถํฐ ์ ์ก๋ฐ๊ธฐ ๋๋ฌธ์ ๋ถํ์ํ ๋ฐ์ดํฐ ํต์ ์ด ๋ฐ์ํ์ง ์๋๋ค.
๋ณ๊ฒฝํ ํ์๊ฐ ์๋ ๋ถ๋ถ์ ๋ค์ ๋ ๋๋งํ์ง ์๋๋ค. ๋ฐ๋ผ์ ํ๋ฉด์ด ์๊ฐ์ ์ผ๋ก ๊น๋นก์ด๋ ํ์์ด ๋ฐ์ํ์ง ์๋๋ค.
ํด๋ผ์ด์ธํธ์ ์๋ฒ์์ ํต์ ์ด ๋น๋๊ธฐ ๋ฐฉ์์ผ๋ก ๋์ํ๊ธฐ ๋๋ฌธ์ ์๋ฒ์๊ฒ ์์ฒญ๋ณด๋ธ ์ดํ ๋ธ๋กํน์ด ๋ฐ์ํ์ง ์๋๋ค.
JSON(JavaScript Object Notation)์ ํด๋ผ์ด์ธํธ์ ์๋ฒ ๊ฐ์ HTTP ํต์ ์ ์ํ ํ ์คํธ ๋ฐ์ดํฐ ํฌ๋งท์ด๋ค. JS์ ์ข ์๋์ง ์๋ ์ธ์ด ๋ ๋ฆฝํ ๋ฐ์ดํฐ ํฌ๋งท์ด๊ธฐ๋๋ฌธ์ ๋๋ถ๋ถ์ ํ๋ก๊ทธ๋๋ฐ ์ธ์ด์์ ์ฌ์ฉํ ์ ์๋ค.
JSON์ ์๋ฐ์คํฌ๋ฆฝํธ์ ๊ฐ์ฒด ๋ฆฌํฐ๋ด๊ณผ ์ ์ฌํ๊ฒ ํค์ ๊ฐ์ผ๋ก ๊ตฌ์ฑ๋ ์์ ํ ์คํธ๋ค.
JSON์ ํค๋ ๋ฐ๋์ ํฐ๋ฐ์ดํ๋ก ๋ฌถ์ด์ผ ํ๋ค. ๊ฐ์ ๊ฐ์ฒด ๋ฆฌํฐ๋ด๊ณผ ๊ฐ์ ํ๊ธฐ๋ฒ์ ๊ทธ๋๋ก ์ฌ์ฉํ ์ ์๋ค. ํ์ง๋ง ๋ฌธ์์ด์ ๋ฐ๋์ ํฐ๋ฐ์ดํ๋ก ๋ฌถ์ด์ผํ๋ค. ์์ ๋ฐ์ดํ๋ ์ฌ์ฉ์ด ๋ถ๊ฐํ๋ค.
JSON.stringify ๋ฉ์๋๋ ๊ฐ์ฒด๋ฅผ JSON ํฌ๋งท์ ๋ฌธ์์ด๋ก ๋ณํ
ํ๋ค. ํด๋ผ์ด์ธํธ๊ฐ ์๋ฒ๋ก ๊ฐ์ฒด๋ฅผ ์ ์กํ๋ ค๋ฉด ๊ฐ์ฒด๋ฅผ ๋ฌธ์์ดํ ํด์ผ ํ๋๋ฐ ์ด๋ฅผ ์ง๋ ฌํ(serializing)์ด๋ผ ํ๋ค.
JSON.parse ๋ฉ์๋๋ JSON ํฌ๋งท์ ๋ฌธ์์ด์ ๊ฐ์ฒด๋ก ๋ณํ
ํ๋ค.
์๋ฒ โ ํด๋ผ์ด์ธํธ๋ก ์ ์ก๋ JSON๋ฐ์ดํฐ๋ ๋ฌธ์์ด
์ด ๋ฌธ์์ด์ ๊ฐ์ฒด๋ก ์ฌ์ฉํ๋ ค๋ฉด ๊ฐ์ฒดํ(์ญ์ง๋ ฌํ) ํด์ผ๋๋ค.
JSON
์ ๋ฌธ์์ด๋ก ๋ฐํ๋์ด ์๋ ๊ฒฝ์ฐ, JSON.parse
๋ ๋ฌธ์์ด โ ๋ฐฐ์ด ๊ฐ์ฒด๋ก ๋ณํ
๐ก ๋ฐฐ์ด์ด JSON ํฌ๋งท์ ๋ฌธ์์ด๋ก ๋ณํ๋์ด ์๋ ๊ฒฝ์ฐ JSON.parse๋ ๋ฌธ์์ด์ ๋ฐฐ์ด ๊ฐ์ฒด๋ก ๋ณํํ๋ค. ๋ฐฐ์ด์ ์์๊ฐ ๊ฐ์ฒด์ธ ๊ฒฝ์ฐ ๋ฐฐ์ด์ ์์๊น์ง ๊ฐ์ฒด๋ก ๋ณํํ๋ค.
๋ธ๋ผ์ฐ์ ๋ ์ฃผ์์ฐฝ์ด๋ HTML์ form ํ๊ทธ ๋๋ a ํ๊ทธ๋ฅผ ํตํด HTTP ์์ฒญ ์ ์ก ๊ธฐ๋ฅ์ ๊ธฐ๋ณธ ์ ๊ณตํ๋ค. ์๋ฐ์คํฌ๋ฆฝํธ๋ฅผ ์ฌ์ฉํ์ฌ HTTP ์์ฒญ์ ์ ์กํ๋ ค๋ฉด XMLHttpRequest ๊ฐ์ฒด๋ฅผ ์ฌ์ฉํ๋ค.
XMLHttpRequest ๊ฐ์ฒด๋ XMLHttpRequest ์์ฑ์ ํจ์๋ฅผ ํธ์ถํ์ฌ ์์ฑํ๋ค.
์ด ๊ฐ์ฒด๋ ๋ธ๋ผ์ฐ์ ์์ ์ ๊ณตํ๋ Web API์ด๋ฏ๋ก ๋ธ๋ผ์ฐ์ ํ๊ฒฝ์์๋ง ์ ์ ์คํ๋๋ค.
XMLHttpRequest๋ ๋ค์ํ ํ๋กํผํฐ์ ๋ฉ์๋๋ฅผ ์ ๊ณตํ๋ค.
๋ํ์ ์ธ ํ๋กํผํฐ์ ๋ฉ์๋๋ ๋ค์๊ณผ ๊ฐ๋ค.
XMLHttpRequest ๊ฐ์ฒด์ ํ๋กํ ํ์ ํ๋กํผํฐ
XMLHttpRequest ๊ฐ์ฒด์ ์ด๋ฒคํธ ํธ๋ค๋ฌ ํ๋กํผํฐ
XMLHttpRequest ๊ฐ์ฒด์ ๋ฉ์๋
XMLHttpRequest ๊ฐ์ฒด์ ์ ์ ํ๋กํผํฐ
HTTP ์์ฒญ์ ์ ์กํ๋ ๊ฒฝ์ฐ ๋ค์ ์์๋ฅผ ๋ฐ๋ฅธ๋ค.
XMLHttpRequestp.prototype.setRequestHeader ๋ฉ์๋๋ก ํน์ HTTP ์์ฒญ์ ํค๋ ๊ฐ์ ์ค์ ํ๋ค.
ํ์์ ๋ฐ๋ผ์ XMLHttpRequest.prototype.setRequestHeader ๋ฉ์๋๋ก ํน์ HTTP ์์ฒญ์ ํค๋ ๊ฐ์ ์ค์ ํ๋ค
XMLHttpRequest.prototype.send ๋ฉ์๋๋ก HTTP ์์ฒญ์ ์ ์กํ๋ค.
XMLHttpRequest.prototype.open open ๋ฉ์๋๋ ์๋ฒ์ ์ ์กํ HTTP ์์ฒญ์ ์ด๊ธฐํํ๋ค. open ๋ฉ์๋๋ฅผ ํธ์ถํ๋ ๋ฐฉ๋ฒ์ ๋ค์๊ณผ ๊ฐ๋ค
์ฃผ๋ก 5๊ฐ์ง ์์ฒญ ๋ฉ์๋๋ฅผ ์ด์ฉํ์ฌ CRUD๋ฅผ ๊ตฌํํ๋ค.
XMLHttpRequest.prototye.send
send ๋ฉ์๋๋ open ๋ฉ์๋๋ก ์ด๊ธฐํ๋ HTTP ์์ฒญ์ ์๋ฒ์ ์ ์กํ๋ค. ๊ธฐ๋ณธ์ ์ผ๋ก ์๋ฒ๋ก ์ ์กํ ๋๋ GET, POST ์์ฒญ ๋ฉ์๋์ ๋ฐ๋ผ ์ ์ก ๋ฐฉ์์ ์ฐจ์ด๊ฐ ์๋ค.
GET ์์ฒญ ๋ฐ์ดํฐ๋ฅผ URL์ ์ผ๋ถ์ธ ์ฟผ๋ฆฌ ๋ฌธ์์ด๋ก ์๋ฒ์ ์ ์กํ๋ค.
POST ์์ฒญ ๋ฉ์๋์ ๊ฒฝ์ฐ ๋ฐ์ดํฐ๋ฅผ ์์ฒญ ๋ชธ์ฒด์ ๋ด์ ์ ์กํ๋ค.
send ๋ฉ์๋์๋ ์ ์กํ ๋ฐ์ดํฐ๋ฅผ ์ธ์๋ก ์ ๋ฌํ ์ ์๋ค. ํ์ด๋ก๋๊ฐ ๊ฐ์ฒด์ธ ๊ฒฝ์ฐ ๋ฐ๋์ JSON.stringfy ๋ฉ์๋๋ฅผ ์ฌ์ฉํด ์ง๋ ฌํํ ๋ค์ ์ ๋ฌํด์ผํ๋ค.
XMLHttpRequest.prototype.setRequestHeader
setRequestHeader ๋ฉ์๋๋ ํน์ HTTP ์์ฒญ์ ํค๋ ๊ฐ์ ์ค์ ํ๋ค.
๋ฐ๋์ open ๋ฉ์๋๋ฅผ ํธ์ถํ ์ดํ์ ํธ์ถํด์ผ ํ๋ค.
Content-type์ ์์ฒญ ๋ชธ์ฒด์ ๋ด์ ์ ์กํ ๋ฐ์ดํฐ์ MIME ํ์ ์ ์ ๋ณด๋ฅผ ํํํ๋ค.
์๋ฒ๊ฐ ์ ์กํ ์๋ต์ ์ฒ๋ฆฌํ๋ ค๋ฉด XMLHttpRequest ๊ฐ์ฒด๊ฐ ๋ฐ์ ์ํค๋ ์ด๋ฒคํธ๋ฅผ ์บ์นํด์ผ ํ๋ค.
์ด ์ด๋ฒคํธ ํธ๋ค๋ฌ ํ๋กํผํฐ ์ค, HTTP ์์ฒญ์ด ํ์ฌ ์ํ๋ฅผ ๋ํ๋ด๋ readyState ํ๋กํผํฐ ๊ฐ์ด ๋ณ๊ฒฝ๋ ๊ฒฝ์ฐ ๋ฐ์ํ๋ readystatechange ์ด๋ฒคํธ๋ฅผ ์บ์นํ์ฌ ๋ค์๊ณผ ๊ฐ์ด ์๋ต์ ์ฒ๋ฆฌํ ์ ์๋ค.
ํ๋กํ ํ์ ํ๋กํผํฐ | ์ค๋ช |
---|---|
์ด๋ฒคํธ ํธ๋ค๋ฌ ํ๋กํผํฐ | ์ค๋ช |
---|---|
๋ฉ์๋ | ์ค๋ช |
---|---|
์ ์ ํ๋กํผํฐ | ๊ฐ | ์ค๋ช |
---|---|---|
๋งค๊ฐ๋ณ์ | ์ค๋ช |
---|---|
HTTP ์์ฒญ ๋ฉ์๋ | ์ข ๋ฅ | ๋ชฉ์ | ํ์ด๋ก๋ (์ ์ก ๋ ๋ฐ์ดํฐ ์ ๋ฌด) |
---|---|---|---|
MIME ํ์ | ์๋ธํ์ |
---|---|
readyState
HTTP ์์ฒญ์ ํ์ฌ ์ํ๋ฅผ ๋์ฌํ๋ ์ ์. ๋ค์๊ณผ ๊ฐ์ ์ ์ ํ๋กํผํฐ๋ฅผ ๊ฐ์ผ๋ก ๊ฐ๋๋ค. (๋งจ ๋ฐ์ ๋์ด)
status
HTTP ์์ฒญ์ ๋ํ ์๋ต ์ํ๋ฅผ ๋ํ๋ด๋ ์ ์ EX) 200
statusText
HTTP ์์ฒญ์ ๋ํ ์๋ต ๋ฉ์์ง๋ฅผ ๋ํ๋ด๋ ๋ฌธ์์ด EX) โOKโ
responseType
HTTP ์๋ต ํ์ EX) document, json
response
HTTP ์์ฒญ์ ๋ํ ์๋ต ๋ชธ์ฒด, responseType์ ๋ฐ๋ผ ํ์ ์ด ๋ค๋ฅด๋ค.
onreadystatechange
readyStateํ๋กํผํฐ ๊ฐ์ด ๋ณ๊ฒฝ ๋ ๊ฒฝ์ฐ
onerror
HTTP ์์ฒญ์ ์๋ฌ๊ฐ ๋ฐ์ํ ๊ฒฝ์ฐ
onload
HTTP ์์ฒญ์ด ์ฑ๊ณต์ ์ผ๋ก ์๋ฃํ ๊ฒฝ์ฐ
open
HTTP ์์ฒญ ์ด๊ธฐํ
send
HTTP ์์ฒญ ์ ์ก
abort
์ด๋ฏธ ์ ์ก๋ ์์ฒญ ์ค๋จ
setRequestHeader
ํน์ HTTP ์์ฒญ ํค๋์ ๊ฐ์ ์ค์
UNSENT
0
open ๋ฉ์๋ ํธ์ถ ์ด์
OPEND
1
open ๋ฉ์๋ ํธ์ถ ์ดํ
HEADERS_RECEIVED
2
send ๋ฉ์๋ ํธ์ถ ์ดํ
LOADING
3
์๋ฒ ์๋ต ์ค
DONE
4
์๋ฒ ์๋ต ์๋ฃ
method
HTTP ์์ฒญ ๋ฉ์๋ (โGETโ, โPOSTโ, โPUTโ, โDELETEโ๋ฑ )
url
HTTP ์์ฒญ์ ์ ์กํ URL
async
๋น๋๊ธฐ ์์ฒญ ์ฌ๋ถ, ์ต์ ์ผ๋ก ๊ธฐ๋ณธ ๊ฐ์ true์ด๋ฉฐ ๋น๋๊ธฐ ๋ฐฉ์์ผ๋ก ๋์ํ๋ค.
GET
index/retrieve
๋ชจ๋ /ํน์ ๋ฆฌ์์ค ์ทจ๋
X
POST
create
๋ฆฌ์์ค ์์ฑ
O
PUT
replace
๋ฆฌ์์ค ์ ์ฒด ๊ต์ฒด
O
PATCH
modify
๋ฆฌ์์ค ์ผ๋ถ ์์
O
DELETE
delete
๋ชจ๋ /ํน์ ๋ฆฌ์์ค ์ญ์
X
text
text/plain, text/html, text/css, text/javascript
application
application/json, application/x-www-form-urlencode
multipart
multipart/form-data