본문으로 바로가기

[자바스크립트]JSON.stringify(), JSON.parse()

category FrontEnd 2021. 1. 7. 00:17
728x90
반응형

자바스크립트와 JSON

JSON(JavaScript Object Notation)은 자바 스크립트 객체 문법으로 구조화된 데이터를 표현하기 위한 문자 기반의 표준 포맷이다.

웹 어플리케이션에서 데이터를 전송할 때 일반적으로 사용하므로 JSON 데이터는 자바스크립트가 자주 사용되는

웹 환경에서 사용하는 것이 유리하다.

 

자바스크립트에서 JSON 데이터를 분석하고 사용하는 것은 매우 간단하다.

자바스크립트는 JSON 데이터를 처리하기 위한 다음과 같은 메소드를 제공한다.

 

1. JSON.stringify()

2. JSON.parse()

3. toJSON()

 


1. JSON.stringify() 메소드

JSON.stringify() 메소드는 인수로 전달받은 자바스크립트 객체를 문자열로 변환하여 반환

* 문법 : JSON.stringify(value)

value에는 변환할 자바스크립트 객체를 전달한다.

이 메소드는 UTF-16으로 인코딩된 JSON 형식의 문자열을 반환

// 자바스크립트 객체
var dog = {name: "식빵",
               family: "웰시코기", 
               age: 1, weight: 2.14
              }; 
var data = JSON.stringify(dog);                    // 자바스크립트 객체를 문자열로 변환함.
document.getElementById("json").innerHTML = data;

2. JSON.parse() 메소드

JSON.parse() 메소드는 JSON.stringify() 메소드와는 반대로 인수로 전달받은 문자열을 자바스크립트 객체로 변환하여 반환

* 문법 : JSON.parse(text)

text에는 변환할 문자열을 전달

이때 해당 문자열은 반드시 유효한 JSON 형식의 문자열이어야 한다.

* JSON 형식에 맞지 않는 문자열을 전달하면 오류 발생

* JSON.parse() 메소드는 오직 JSON 형식의 문자열만을 변환할 수 있다.

// JSON 형식의 문자열
var data = '{"name": "식빵", "family": "웰시코기", "age": 1, "weight": 2.14}';
// JSON 형식의 문자열을 자바스크립트 객체로 변환
var dog = JSON.parse(data);                      

document.getElementById("json").innerHTML = dog + "<br>";
document.getElementById("json").innerHTML += dog.name + ", " + dog.family;

3. toJSON() 메소드

자바스크립트의 toJSON() 메소드는 자바스크립트의 Date 객체의 데이터를 JSON 형식의 문자열로 변환하여 반환

따라서 이 메소드는 Date.prototype 객체에서만 사용할 수 있다.

 

toJSON() 메소드는 접미사 Z로 식별되는 UTC 표준 시간대의 날짜를 ISO 8601 형식의 문자열로 반환

따라서 이 문자열은 언제나 24개나 27개의 문자로 이루어지며, 다음과 같은 형식을 따른다.

// 자바스크립트 Date 객체
var date = new Date();   
// Date 객체를 JSON 형식의 문자열로 변환
var str = date.toJSON(); 

document.getElementById("json").innerHTML = date + "<br>";
document.getElementById("json").innerHTML += str;
반응형