JavaScript

[JSON] JS - JSON - JSON.parse() 함수 ★ - (JSON문자열 → JS객체) 변환. (= 웹서버와 데이터 교환해 가져온 데이터를 복원)

개괄


JSON은 웹 서버와 데이터를 교환하는 데 주로 사용. 

웹 서버에서 데이터를 수신 할 때 데이터는 항상 문자열임. 

JSON.parse() 사용하여 데이터를 파싱하면 데이터가 기본적으로 JS 객체로 반환됨. (예외도 있음)

 

 

 

 

예제1 - JSON 파싱 기본 형태

 

<!DOCTYPE html>

<html>

<body>


<p id="hz"></p>


<script>

var txt = '{"name":"홈짱닷컴", "domain":"Homzzang.com", "year":2012}'

var obj = JSON.parse(txt);

document.getElementById("hz").innerHTML = obj.name + ", " + obj.domain + ", " + obj.year;

</script>


</body>

</html>


결과값: 홈짱닷컴 Homzzang.com 2012

※ txt 변수에 들어간 내용을 웹서버에서 가져왔단 가정.
※ 텍스트가 JSON 형식 구문이 아닌 경우 에러 발생 함.

 

 

 

예제2 - JSON 파싱 (JS 객체 반환)


test.js 내용

{

    "name":"홈짱닷컴",

    "domain": "Homzzang.com",

    "since": 2012,

    "subject":[

        { "subject":"HTML", "intro":"홈페이지 뼈대" },

        { "subject":"CSS", "intro":"홈페이지 디자인" },

        { "subject":"JS", "intro":"홈페이지 동적기능" }

    ]

}

 

 

<!DOCTYPE html>

<html>

<body>


<p id="homzzang"></p>


<script>

var xmlhttp = new XMLHttpRequest();

xmlhttp.onreadystatechange = function() {

    if (this.readyState == 4 && this.status == 200) {

        var hz = JSON.parse(this.responseText);

        document.getElementById("homzzang").innerHTML = 

            hz.name + " " + hz.domain + " " + hz.since;

    }

};

xmlhttp.open("GET", "test.js", true);

xmlhttp.send();


</script>


</body>

</html>

 

 

 

 

예제3 - 배열 파싱 (JS 배열 반환)


test.js 내용

[ "홈짱닷컴", "Homzzang.com", 2012]

 


<!DOCTYPE html>

<html>

<body>


<p id="homzzang"></p>


<script>

var xmlhttp = new XMLHttpRequest();

xmlhttp.onreadystatechange = function() {

    if (this.readyState == 4 && this.status == 200) {

        var hz = JSON.parse(this.responseText);

        document.getElementById("homzzang").innerHTML = 

            hz[0] + " " + hz[1] + " (Since " + hz[2]+ ")";

    }

};

xmlhttp.open("GET", "test.js", true);

xmlhttp.send();

</script>

 

</body>

</html>

 

 

 

 

예외

 

 

 

예외1 - 날짜 파싱 (문자열로 파싱 후, 나중에 다시 날짜 형식으로 변환) 

 

 

Date 객체는 JSON에서 사용할 수 없음.


날짜를 포함해야하는 경우, 이를 문자열로 표기.


나중에 다시 날짜 객체로 변환 가능

 

 
방법1


<!DOCTYPE html>

<html>

<body>


<p id="homzzang"></p>


<script>

var text = '{"site":"홈짱닷컴", "domain":"Homzzang.com", "today":"2018-08-11"}';

var hz = JSON.parse(text);

hz.today = new Date(hz.today);

document.getElementById("homzzang").innerHTML = 

   hz.site + ", " + hz.domain + ", " + hz.today; 

</script>


</body>

</html>

 


방법2 - json.parse 함수의 두 번째 매개변수 활용

 

 

<!DOCTYPE html>

 

<html>

<body>


<p id="homzzang"></p>


<script>

var text = '{"site":"홈짱닷컴", "domain":"Homzzang.com", "today":"2018-08-11"}';

var hz = JSON.parse(text, function (key, value) {

    if (key == "today") {

        return new Date(value);

    } else {

        return value;

    }});

document.getElementById("homzzang").innerHTML = 

   hz.site + ", " + hz.domain + ", " + hz.today; 

</script>


</body>

</html>

 

 

 

 

예외2 - 함수 파싱 (문자열로 파싱 후, 나중에 다시 함수로 변환)

 

 

함수는 JSON에서 사용할 수 없음. (왜냐면, 함수가 그 적용 범위를 잃음)


함수를 포함해야하는 경우, 이를 문자열로 표기.

 

나중에 eval() 메서드 이용해 다시 함수로 변환 가능

 

 

<!DOCTYPE html>

<html>

<body>


<p id="homzzang"></p>


<script>

var text = '{"site":"홈짱닷컴", "domain":"Homzzang.com", "since":"function() {return 2012;}"}';

var hz = JSON.parse(text);

hz.since = eval("(" + hz.since + ")");

document.getElementById("homzzang").innerHTML = 

   hz.site + ", " + hz.domain + ", " + hz.since()

</script>


</body>

</html>


 

 

 

 

지원 브라우저

 

JSON.parse () 함수는 모든 주요 브라우저와 최신 ECMAScript (JavaScript) 표준에 포함되어 있음.

 


Web Browsers Support

Firefox 3.5

Internet Explorer 8

Chrome

Opera 10

Safari 4

 


구형 브라우저의 경우,
https://github.com/douglascrockford/JSON-js 에서 JS 라이브러리 사용

 


방문 감사합니다. (즐겨찾기 등록: Ctrl + D)

분류 제목
DOM JS - CSS - 스타일변경
DOM JS - Animation - 애니메이션 (= 동적효과 = 움직임효과)
DOM JS - Events - 이벤트 2
DOM JS - addEventListener() 메서드 ★★★★★ - 이벤트 걸기 (= addEventListen…
DOM JS - Navigation - 노드탐색 (= 요소탐색) ※ 텍스트노드복사
DOM JS - Node - 노드추가, 노드삭제, 노드변경 (= 노드생성, 노드제거, 노드교체)
DOM JS - Collection - HTML요소집합 (= HTML요소묶음)
BOM JS - Window BOM - 윈도우 브라우저객체모델 (BOM: Browser Object Model)
BOM JS - Window Screen 객체 - 화면객체 (= 스크린객체 = screen객체)
BOM JS - Window Location 객체 - 위치객체 (= 로케이션객체 = Location객체) ※ loc…
BOM JS - Window History 객체 - 이력객체 (= 히스토리객체 = History객체 = 뒤로가기 +…
BOM JS - Window Navigator 객체 - 브라우저객체 (= 네이게이터객체 = Navigator객체 =…
BOM JS - Popup Boxes - 팝업상자 (= 팝업박스 = Alert Box + Confirm box + …
BOM JS - Timing Events ★ - 시간간격 코드실행 (= 타이밍 이벤트 = 시간이벤트 = 일정시간별 …
BOM JS - Cookie (쿠키) 사용법 ★★★ - 쿠키 (설정・생성) / 쿠키 (읽기・얻기・가져오기) / 쿠…
5/89
목록
  • 채팅방
  • 필독
1. 채팅창 헤드에서 접속자 확인 2. 닉네임 클릭해 1:1 채팅 가능 3. 닉네임 클릭해 귓속말 가능 4. 닉네임 클릭해 호출하기 가능 5. 우하단 클릭해 환경 설정 가능 6. 의뢰글 작성 후 의뢰 상담 가능 7. 질문글 작성 후 질문 상담 가능 8. 채팅방에 개인정보 입력 금지 9. 채팅방에 광고 욕설 비방 금지
 홈  PC버전 로그인 일본어
웹디자인언어
서버관리언어
고급코딩언어
그누보드
제작의뢰
Q&A
커뮤니티 2
웹유틸
회원센터
홈짱 PC버전 로그인