1K подписчиков

Как дебажить JavaScript код

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.

Источник: WebForMyself.com

Урок по решению любой проблемы в JavaScript с помощью отладки. Отладка – отличный навык для решения любых проблем в JS коде.

Каждый день мы просыпаемся, завтракаем, идем к компьютеру, садимся и пишем идеальный код, который делает именно то, что мы хотим. А потом мы просыпаемся. Было бы круто, правда? Но это лишь сон.

Насколько бы хорошим кодером вы не были, вы не сможете писать код без багов. Код по определению не может быть без багов. Баг – это та проблема, которую вы не заметили или не ожидали, когда сели писать код. Баг может быть обнаружен только после релиза. Это хуже всего.

Баг можно поймать самому во время тестирования программы. Он даже может возникнуть из-за изменения всего одной строки кода (даже если ранее код работал идеально). Такие баги называют регрессионными.

Баги являются частью нашей повседневной жизни, как разработчиков. Однако наша задача максимально уменьшить их количество. Отлаживать код легко, когда вы умеете бороться с багами.

Как бороться с багами?

Во-первых, постарайтесь избегать их, тщательно продумывая, как ваша программа будет работать. Еще до написания кода. Далее анализируйте каждую строку кода на возможные ошибки и посторонние или неожидаемые эффекты.

Но баги всегда проходят мимо радаров. Никто не вносит баги намеренно. Часто ошибки всплывают только, когда программа уже в проде и используется клиентами.

Вот вы знаете, что есть баг. Как его исправить? Самое сложное – определить место возникновения бага. Когда вы знаете все, что написано выше, решить баг уже достаточно просто.

Обычно для решения бага мы используем 2 способа. Первая техника достаточно базовая – необходимо выяснить значения стейта (переменных) и выполнением программы и вывести эти переменные в лог или в вывод вашей программы.

Локализация ошибки

Отладка – базовый навык для разработчика. Иногда мы делаем все возможное, но программа работает неправильно. Она может вылетать, работать медленно или выводить неверную информацию.

Что делать, если ваша программа ведет себя неправильно? Начать отладку. Первый шаг – понять, что происходит и попробовать определить место, откуда начинается проблема.

Проблема в окружении? Проблема во входных данных? Может, это разовый вылет из-за нехватки памяти? Или проблема воспроизводится постоянно? Все эти вопросы укажут вам направление для решения проблемы.

Зная место в коде, можно приступить к изучению этого куска кода. Самый простой способ отладки с точки зрения инструментов – просто читать свой код вслух. Есть некая магия в том, когда мы проговариваем что-то вслух. Часто я нахожу ошибку именно так. Если не помогло, то пора переходить к инструментам.

Первое знакомство с alert() и console.log()

Если чтение кода не помогло, можно добавить пару строк в свой код. В JavaScript коде фронта вы часто будете использовать alert() и console.log. Разберем код ниже:

По каким-то неизвестным нам причинам мы получаем неверный результат. Поэтому мы добавим alert(a) и alert(b) перед вычислением результата. В браузере откроется 2 алерт окна при выполнении кода:

Все работает, если в alert() передавать строку или чисто. Если у вас массивы или объекты, то alert() уже не справится. Вам понадобится console.log():

Значения напечатаются в JS консоли браузера в панели разработчика.

Проверка объектов

У нас есть объект car, но мы не знаем, что у него внутри. Но хотим узнать:

Узнать что внутри можно разными способами.

console.log

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-2

console.dir

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-3

В Node.js можно добавить свойство colors для добавления цветов в терминал:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-4

JSON.stringify()

Эта команда распечатает объект как строку:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-5

Если добавить следующие параметры:

Вывод в консоли станет красивее. Последний аргумент определяет чисто отступов:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-6

У JSON.stringify() есть преимущество при вызове не из консоли. Объекты можно выводить на экран.

Перебор свойств в цикле

Вывести в консоль все свойства объекта можно с помощью цикла for…in:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-7

Отладчик браузера

Очень важно уметь дебажить программы, которые работают неправильно. Один из инструментов для поиска багов – отладчик. Отладчик может поставляться сразу с компилятором языка программирования или с дополнительными инструментами.

Например, в Visual Studio Code editor от Microsoft есть JS дебагер. Еще один отладчик есть в браузере.

С помощью отладчика можно остановить программу в любом месте, проверить значения переменных, выполнить любой код и пошагово пройтись по каждой строке.

Если в браузере добавить выражение debugger, это остановит рендер страницы и запустит режим отладки. Отладчик – самый мощный инструмент в панели разработчика в браузере. Его можно найти на вкладке Sources:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-8

Верхняя часть экрана – навигация по файлам. Можно выбрать любой файл и открыть его справа. Очень важно ставить точки остановки. Чуть позже мы разберем их. Нижняя часть это и есть сам отладчик.

Точки остановки

При загрузке страницы браузером JS код выполняется до точки остановки. На этой точке программа останавливается, и вы можете проверить все переменные в программе. Можно проверить значения переменных, а также продолжить пошаговое выполнение программы по одной строке.

Но что такое точка остановки? Простым языком, точка остановки — это инструкция breakpoint, вставленная в ваш код. Когда браузер натыкается на нее, он останавливается.

Неплохой вариант при разработке. Другой способ – открыть файл в панели Sources и кликнуть на номер строки, где хотите добавить точку остановки:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-9

Повторный клик убирает точку. После добавления точки нужно обновить страницу, и код остановится, когда добежит до точки.

После добавления точки остановки ее можно заметить на панели Breakpoints. Видно, что точка остановки стоит в файле form.js на 7 строке. На этой панели отображаются все точки остановки. Их также можно временно отключить.

Есть и другие типы точек остановки:

  • XHR/fetch брейкпоинты – срабатывают при отправке любых запросов
  • DOM брейкпоинты – срабатывают при изменении элементов DOM
  • Слушатели событий – срабатывают при выполнении событий. Например, клик мыши
Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-10

Область видимости

В этом примере я поставил брейкпоинт внутри слушателя события. Поэтому мне нужно отправить форму, чтобы брейкпоинт сработал:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-11

Все переменные в области видимости отображаются на вкладке Scope. Переменные можно редактировать через двойной клик.

Наблюдение за переменными и выражениями

Справа от Scope есть панель Watch. С помощью кнопки + можно добавить любое выражение. Можно добавить name, и распечатается значение переменной name. Например, значение Flavio. Можно добавить name.toUpperCase(), и выведется FLAVIO:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-12

Продолжить выполнение

Скрипт остановлен, так как код добежал до точки остановки. Над надписью «Paused on breakpoint» есть панель с кнопками, с помощью которых можно менять это состояние.

Первая синяя кнопка продолжит нормальное выполнение скрипта. Вторая — step over – перейти на следующую строку и остановиться. Следующая — step into – проваливается в функции. Step out – делает обратный ход – выходит из вызванной функции. Это основные кнопки для управления отладкой.

Редактирование скриптов

В панели разработчика можно редактировать любой скрипт, даже если скрипт остановлен. Просто отредактируйте файл и нажмите cmd-S на Mac или ctrl-S на Windows/Linux.

Конечно, изменения не сохраняются на диск, если только вы не работаете локально и не настроили рабочее окружение в панели разработчика. Но это уже более продвинутая тема.

Работа со стеком вызовов

В панели call stack можно увидеть, насколько глубоко вы погрузились в JS код. Можно переместиться вверх, если кликнуть на имя функции в стеке:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-13

Печать стек трейса

В некоторых ситуациях полезно распечатать стек трейс вызовов функций. Иногда это помогает ответить на вопрос, как я попал в эту часть кода? Для этого используйте console.trace():

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-14

Логирование ошибок разного уровня

Как мы выше убедились, console.log – классный способ вывода сообщений в консоль. Рассмотрим 3 более удобных метода для дебага. Они подчеркивают различные уровни ошибок.

Первый, console.info()

Перед логом печатается маленькая «i», четко указывающая, что лог просто информативный.

Второй, console.warn()

Печатает желтый восклицательный знак. Если включить тулбар с фильтрами в консоли, то можно заметить, что сообщения можно фильтровать по типу. Фильтровать сообщения действительно удобно. Если мы кликнем на Warnings, все сообщения не относящиеся к предупреждениям будут скрыты.

Третий, console.error()

Этот тип отличается от остальных. Помимо красного Х выводится весь стек трейс функции с ошибкой. И мы можем пойти пофиксить ее.

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-15

Сохранение логов при навигации

Сообщения в консоли очищаются при каждом переходе по страницам, если не поставить галку Preserve log в настройках:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-16

Группировка сообщений в консоли

Сообщения в консоли могут становиться все больше и больше, и этот мусор может сбить вас с толку во время отладки.

Дабы решить эту проблему, Console API предлагает полезную функцию – группировка сообщений в консоли. Разберем на примере:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-17

Консоль создает группу, внутри которой находятся наши сообщения. Можно сделать то же самое только с закрытой группой, чтобы не засорять лог. Раскрыть группу можно по клику.

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-18

Группы могут быть вложенными:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-19

Blackbox скрипты

Часто приходится работать с библиотеками, где не хочется спускаться в их код. Вы им доверяете и не хотите видеть их код в стек трейсе. Как в примере выше для validator.min.js, который я использую для валидации почты.

Я знаю, что этот скрипт работает как надо. Я могу кликнуть правой кнопкой мыши в стеке вызовов и выбрать Blackbox script. После этого нельзя провалиться в код этого скрипта. И вы можете счастливо работать только над кодом своего приложения.

Панель разработчика в браузере для отладки Node.js

Так как Node.js построен на движке Chrome v8, то можно связать их и использовать Chrome DevTools для дебага Node.js приложений. В терминале выполните команду:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-20

В Chrome перейдите по адресу about://inspect:

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-21

Кликните на ссылку Open dedicated DevTools for Node. Это откроет панель разработчика для Node.js.

Источник: WebForMyself.com Урок по решению любой проблемы в JavaScript с помощью отладки.  Отладка – отличный навык для решения любых проблем в JS коде.-22

Нужно кликнуть именно на эту ссылку, а не на inspect ниже. Наш вариант автоматически переподключается к Node.js, когда мы перезапускаем его – очень удобно!

Читайте нас в Telegram, VK

Источник: flaviocopes.com

#javascript #отладка