• 회원가입
  • 로그인
  • 구글아이디로 로그인

[JSON] JS - JSON - JSON.stringify() 함수 ★ - (JS객체 → JSON문자열) 변환. ※ PHP var_dump(), print_r() 유사 역할 가능 ※ 객체 (내용/요소/키값쌍) 줄바꿈 출력/확인

목차

  1. JSON.stringify() 정의 - (JS객체 → JSON문자열) 변환
  2. JSON.stringify() 예제 - JS객체를 문자열로 만들기
  3. JSON.stringify() 예제 - JS배열을 문자열로 만들기
  4. JSON.stringify() 예외1 - 날짜를 문자열로 만들기
  5. JSON.stringify() 예외2 - 함수를 문자열로 만들기
  6. JSON.stringify() 예제 - 객체의 (타입/내용) 확인

 

JSON.stringify() 정의 - (JS객체 → JSON문자열) 변환


JS 객체를 문자열 (즉, JSON 형태)로 변환

 



1.

  • JSON은 웹 서버와 데이터 교환하는 데 주로 사용.
  • 데이터를 웹 서버로 보낼 때 문자열 형태이어야 함.
  • JSON.stringify()로 JS 객체를 문자열 (즉, JSON 객체)로 변환 함.

 

2.

IE8이상 주요 최신 브라우저 모두 지원.

 

 

JSON.stringify() 예제 - JS객체를 문자열로 만들기

 

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


<script>

var obj = { site: "홈짱닷컴", open: 2012, domain: "Homzzang.com" }; // obj 변수 = JS 객체 상태

var hzJSON = JSON.stringify(obj); // hzJSON 변수 = 문자열 상태 (= JSON 객체 상태)

document.getElementById("homzzang").innerHTML = hzJSON;

</script>


결과보기

 

JSON.stringify() 예제 - JS배열을 문자열로 만들기

 

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


<script>

var arr = [ "홈짱닷컴", "2012", "Homzzang.com"]; // arr 변수 = JS 배열 상태

var hzJSON = JSON.stringify(arr); // hzJSON 변수 = 문자열 상태

document.getElementById("homzzang").innerHTML = hzJSON;

</script>


결과보기


예외 (2개)

 

JSON.stringify() 예외1 - 날짜를 문자열로 만들기

 

JSON에서는 날짜 객체 허용 않음. 

JSON.stringify () 함수는 모든 날짜를 문자열로 변환.

※ 문자열을 수신기에서 날짜 객체로 다시 변환 가능.


 

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


<script>

var obj = { site: "홈짱닷컴", today: new Date(), domain: "Homzzang.com" };

var hzJSON = JSON.stringify(obj);

document.getElementById("homzzang").innerHTML = hzJSON;

</script>


결과보기

 

JSON.stringify() 예외2 - 함수를 문자열로 만들기

 

JSON에서는 함수가 객체 값으로 허용 않음.

JSON.stringify() 함수는 와  모두 JavaScript 객체에서 모든 함수를 제거. (즉, 핑크색부분제거)

 

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


<script>

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

var hzJSON = JSON.stringify(obj);

document.getElementById("homzzang").innerHTML = hzJSON;

</script>


결과보기


단, 

JSON.stringify() 함수 실행 전 JS 객체 안의 함수를 문자열로 변환하면 함수 출력 가능.

 

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


<script>

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

obj.open = obj.open.toString();

var hzJSON = JSON.stringify(obj);

document.getElementById("homzzang").innerHTML = hzJSON;

</script>



결과보기


[명심할 사항 !!]

 

1.

JSON에서는 되도록 함수 사용 자제

왜냐면, 함수가 적용 범위 잃기 때문.


2.
문자열을 다시 함수로 다시 변환하려면 eval () 함수 사용.

 


 

JSON.stringify() 예제 - 객체의 (타입/내용) 확인

 

<script src="https://code.jquery.com/jquery-latest.js"></script>


<script>

var hz = { site: "홈짱닷컴", open: 2012, domain: "Homzzang.com" };


// 방법1 - 웹에 객체 타입 출력

document.write(hz);

// 결과값: [object HTMLDocument]


// 방법2 - 웹에 객체 '키/값' 출력

const json = JSON.stringify(hz); // 객체 -> JSON 문자열로 변환

document.write(json); // JSON 문자열 출력

// 결과값: {"site":"홈짱닷컴","open":2012,"domain":"Homzzang.com"}


// 방법3 - 콘솔에 객체 '키/값' 줄바꿈 출력 (※ 구조 파악 용이)

$.each( hz, function( key, value ){ 

    console.log( 'key:' + key + ' / ' + 'value:' + value ); 

});

// 개발자도구 (F12키 > Console탭)에서 확인 가능

</script>

 


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

분류 제목
String JS - toUpperCase() 메서드 - 대문자로 변환
String JS - trim() 메서드 ★ - 문자열양쪽 공백제거 (= trim메서드 = 트림 메서드)
String JS - valueOf() 메서드 - 객체값 (문자열자체 = 밸류어브)
String JS - anchor() 메서드 - name 속성 갖는 앵커태그 (= 링크태그) (비표준)
String JS - big() 메서드 - 큰글씨 (= 큰글자 = 글자 크게) (비표준)
String JS - blink() 메서드 - 글자 깜빡임. (비표준)
String JS - bold() 메서드 - 굵은글씨 (= 글자 굵게) (비표준)
String JS - fixed() 메서드 - 텔레타이프 텍스트 (비표준)
String JS - fontcolor() 메서드 - 글자색깔 (비표준)
String JS - fontsize() 메서드 - 글자크기 (비표준)
String JS - italics() 메서드 - 이탤릭체 (비표준)
String JS - link() 메서드 - src 속성 갖는 앵커태그 (= 링크태그) (비표준)
String JS - small() 메서드 - 작은글씨 (= 글자 작게) (비표준)
String JS - strike() 메서드 - 취소선 (= strike메서드 = 스트라이크메서드, HTML5제외)
String JS - sub() 메서드 - 아래첨자 (비표준) (= sub메서드 = 서브메서드)
String JS - sup() 메서드 - 위첨자 (비표준)
Number JS - Number -
Number JS - constructor - 객체생성자함수 (숫자 경우)
Number JS - MAX_VALUE - JS최대값 (= JS에서 가장큰수)
Number JS - MIN_VALUE - JS최소값 (= JS가장작은값)
7/67
목록
찾아주셔서 감사합니다. Since 2012