티스토리 뷰
출처 : http://deadfire.hihome.com/jscript/projscript003.html
2.1 console 객체 (자바스크립트 디버깅)
기존에 자바스크립트 코드를 디버깅하는 가장 단순한 방법은 바로 alert()을 사용하여 필요한 정보를 찍어보는 것이었다.alert()을 사용하는 방법은 훌륭하진 않지만, 간단히 사용할 수 있는 꽤 쓸만한 디버깅 방법이다. 다만, 일일이 확인 버튼을 클릭해 주는 일은 불편했던 것이 사실이다. 가끔 for루틴 안에 alert()을 넣고 돌리는 황당한 경험을 한두번씩 했을 것이다.
경험상, 디버깅시에 로그파일에 필요한 정보를 기록하게 되면 디버깅이 훨씬 쉬워진다. 여타 프로그래밍 언어들은 이러한 기능들을 지원하고 있다. 그 개념을 브라우저에서 실행되는 자바스크립를 위해 지원하는 것이 바로 console객체다.
console객체는 IE8 이상 버전과 사파리, 크롬, 오페라같은 최신 브라우저에서 사용할 수 있다. 먼저 간단한 사용 예를 보자.
- var str = "test 입니다";
- console.log(str);
2.2 console 로그 레벨
console의 메소드 중에서 가장 유명한 것이 console.log() 지만, 실제로는 10여개의 메소드들이 존재한다. (다만, 모든 브라우저가 제공하지 않는 기능들도 있기 때문에 사용할 때는 항상 확인해보는 것이 좋다.)로그를 기록하는데 주로 사용되기 때문에 로그등급에 따라서 로그 정보를 출력하는 메소드들이 존재하며, 출력시 아래와 같이 아이콘이 출력된다. (다음은 크롬에서 출력된 결과이다. console.debug()라는 메소드도 있었는데, 현재는 deprecated 상태로 대신 log를 사용하도록 권장하고 있다.)
|
2.3 console.log() 인자
console.log()는 다음과 같이 두가지 방식으로 사용된다.console.log(obj1 [, obj2, ..., objN]); | ex) console.log("a = ", a, ", b = ", b); |
console.log(msg [, subst1, ..., substN]); | ex) console.log(" a is [%d], b is [%s]", a, b); |
첫번째 방식은 일반적으로 객체의 toString()을 호출하여 문자열 합치기로 표현되며, 두번째 방식은 C언어의 printf()함수에서 제공되는 format문자열로 출력할 수 있는 방법(치환문자열, Substitution string)을 제공하고 있다.
치환 문자열로 사용할 수 있는 값들은 다음과 같다.
%o | Javascript Object HypterLink (아래예제와 같이 해당 객체 정보를 훓어볼수 있는 링크를 제공해준다.) |
%d | Integer |
%i | Integer |
%s | String |
%f | Floating-point |
다음과 같이 출력하는 대상이 객체인 경우는 더욱 쓸만하다. 객체를 console.log의 인자로 넘겨주게 되면, 크롬의 경우는 해당 객체의 모든 값을 다 확인할 수 있다. (브라우저의 도구마다 출력결과는 다르다. IE9은 달랑 [object Object]만 출력하고 만다.)
|
'프로그래밍 > JavaScript Web App' 카테고리의 다른 글
자바스크립트 함수 function() (0) | 2013.01.15 |
---|---|
constructor, hasOwnProperty, in 자바스크립트 객체타입 확인 (0) | 2013.01.15 |
자바스크립트(JavaScript) 배열(array) sort, splice, push 정렬,추가,수정,삭제 (0) | 2013.01.14 |
BODY onload에 여러개의 함수를 걸어주기! (0) | 2012.11.20 |
자바스크립트 개발을 하기 전에 꼭 한번 읽어 보세요. (0) | 2012.04.25 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- json
- jQuery Mobile
- css3
- 셀렉터
- Excel
- Style
- Mobile
- JavaScript
- WebApi
- workbook
- WCF
- drag&drop
- MSSQL
- CSS
- jquery chart
- SVG
- IE
- JS
- jQuery
- Ajax
- html5
- radius
- 자바스크립트
- 제이쿼리
- Chart
- 프로시저
- ASP.NET
- grid
- 저장프로시저
- rowspan
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함