퍼블리싱을 배우던 때 개발자였던 지인과 스터디를 한 적이 있었습니다. 디버깅을 할 때 다마 크롬 브라우저 Souces 패널을 사용했는데 굉장히 유용해 보였습니다. 배워야지 하면서 계속 미뤄뒀었는데 이번 유휴 기간 동안 사용법을 익히면서 전반적인 기능을 정리하였습니다.
실행
크롬 개발자 도구(Chorme DevTools)의 Sources 패널에서 디버깅을 할 수 있습니다.
- 윈도우: F12/ ctrl + shift + i
- 맥: command + option + i
data:image/s3,"s3://crabby-images/0597d/0597d49e4824862ee85ecde976a88a26a0470789" alt="img_sources_panel.png"
중단점(Breakpoint)
중단점을 설정 후 해당 이벤트를 발생하면 스크립트 실행을 일시 정지시키고 디버깅 모드로 진입합니다.
행 번호 클릭하여 중단점을 설정할 수 있으며 debugger 탭 Breakpoints에 내역이 생성됩니다. 이 탭 내에서 마우스를 우클릭하면 옵션이 노출됩니다.
data:image/s3,"s3://crabby-images/20b77/20b77610ce5c0e5f944604e4fe67ee43274d4df2" alt="img_breakpoint_1.png"
data:image/s3,"s3://crabby-images/159ac/159ac62109013cd31ddc94414f286c264deb3e3e" alt="img_breakpoint_2.png"
Debugger 탭
탭에 마우스 호버를 하면 기능 명칭과 단축키가 노출됩니다.
순서대로 resume/ step over/ step into/ step out / step/ deactivate breakpoints/ pause on exceptions
data:image/s3,"s3://crabby-images/b90b1/b90b159102f3020c48e3a5af0c261aae5bca018b" alt="img_panel_debugger.png"
resume script execution(F8)
스크립트 재실행
여러 개의 중단점이 있을 경우 각각의 중단점에서 멈추며 추가 중단점이 없을 경우, 디버깅은 종료되어 스크립트를 재실행시킵니다.
step(F9)
다음 코드를 한 줄씩 실행합니다.
step over next fuction call(F10)
다음 코드를 한 줄씩 실행합니다. 현재 실행에 함수가 있다면 함수 안으로는 들어가지 않습니다.
step과 step over next fuction call의 차이점
- step: 함수 호출 시 실행 후 함수 내부로 진입
- step over: 함수 호출 시 실행은 하지만 함수 안으로 진입하지 않음 (내용에 대해 디버깅을 하지 않아도 될 때 쓰임)
data:image/s3,"s3://crabby-images/fc361/fc36190ac2d044ab9ed067d51fa69df2d2106cb3" alt="img_step_vs_step_over_1.png"
data:image/s3,"s3://crabby-images/b54f7/b54f7a960d2092804805f91022b73de8b6bd25aa" alt="img_step_vs_step_over_2.png"
data:image/s3,"s3://crabby-images/ba5bb/ba5bbd7ad7be842e990d52730be0d15bef2b8995" alt="img_step_vs_step_over_3.png"
step into next function call(F11)
다음 코드를 한 줄씩 실행합니다. 현재 실행에 함수가 있다면 함수 안으로 들어가 실행합니다.
step과 step into next function call의 차이점
- step: 비동기는 실행하지 않음
- step into: 비동기 코드로 진입
data:image/s3,"s3://crabby-images/f4976/f49769177175394eee002e2fdae27e6444a93aa7" alt="img_step_vs_step_into_1.png"
data:image/s3,"s3://crabby-images/94f72/94f72847a4c6cfa20c9af3a0e66ddffc1e49798a" alt="img_step_vs_step_into_2.png"
data:image/s3,"s3://crabby-images/6a322/6a322d80a2dcc941ed23ac2a8c370777632f7d5c" alt="img_step_vs_step_into_3.png"
step out of current function(shift + F11)
현재 실행 중인 코드에서 빠져나옵니다.
deactivate breakpoints(ctrl + F8)
모든 중단점을 일시적으로 활성화 혹은 비활성화 합니다.
pause on exceptions
스크립트 실행 중 오류가 발생을 하면 실행이 멈추고 오류가 난 부분을 표시합니다.
Watch
’+’ 버튼을 클릭해 변수나 객체를 등록하면 중단 시점과 실행하는 과정 중에서의 값을 보여줍니다.
data:image/s3,"s3://crabby-images/73b43/73b433dcb855c8cbaf03d0017603a5f7971127a5" alt="img_watch_1.png"
data:image/s3,"s3://crabby-images/5128f/5128f996c66605e2ec08f9b9214cbb7cbeb0f7c5" alt="img_watch_2.png"
Scope
실행 시 정의되어있는 모든 변수의 값을 보여줍니다.
- Local: 함수의 지역 변수
- Global: 함수 바깥에 선언된 전역 변수
Call Stack
실행 경로를 역순으로 보여주며 해당 소스 클릭 시 그 코드로 이동할 수 있습니다.
data:image/s3,"s3://crabby-images/1f888/1f88803ead257e3b727f4481cc8bd65fe10908ad" alt="img_callstack_1.png"
data:image/s3,"s3://crabby-images/b3e6a/b3e6ab07dec23af51d00b15ad2db8e9cb568ca03" alt="img_callstack_2.png"
마치며
브라우저 디버깅은 작업자가 코드를 한 줄 한 줄 실행해가면서 알고자 하는 것을 확인할 수 있는 점이 큰 장점입니다. 따라서 반복문이나 실시간으로 변화하는 값을 확인할 때 유용하였습니다. 대신 단순하고 직관적인 값(오류)을 확인할 때는 alert이나 console이 상대적으로 덜 번거롭게 느껴졌습니다.
여러가지 디버깅 방법을 활용하면서 오류로 보내는 시간을 줄여보아요.
고맙습니다. - 끄읕 -