Продолжение цикла переводов полезных советов для веб-разработчика. Предыдущая часть: 1-16.

Содержание:
   17.  Быстрое редактирование названия HTML-тега в панели «Elements»
   18.  Разворачивание всех дочерних узлов выбранного элемента
   19.  Переключение состояния вкладки DevTools при помощи горячих клавиш
   20.  Переключение на DOM-элемент из DevTools консоли
   21.  Подсветка выполняемого выражения
   22.  Улучшения в работе инструмента Color Picker
   23.  Включение точки останова и навигация по стеку вызовов при помощи горячих клавиш
   24.  Просмотр определения функции, зарегистрированной как обработчик события на DOM-элементе
   25.  Нотификация о JS-ошибке во время написания кода
   26.  Персистентность настроек отображения для режима «Инкогнито»
   27.  Визуализация выбранного режима сглаживания анимации
   28.  Просмотр и изменения точек останова DOM-дерева при помощи панели «Breakpoints»
   29.  Пять интересных возможностей панели «Console»
   30.  Автодополнение свойств и методов объекта в панели «Console»
   31.  Просмотр и отладка обработчиков событий
   32.  Автоматическая остановка выполнения программы при возникновении любых исключений

17. Быстрое редактирование названия HTML-тега в панели «Elements»


Если вам нужно поменять название DOM-узла в панели «Elements», дважды кликните на его открывающий тег и введите новое имя. Закрывающий тег этого элемента будет изменен автоматически.
Посмотреть скринкаст


18. Разворачивание всех дочерних узлов выбранного элемента


Вы можете развернуть все вложенные узлы выбранного элемента, зажав клавишу Alt и кликнув по стрелке рядом с его открывающим тегом.
Посмотреть скринкаст


19. Переключение состояния вкладки DevTools при помощи горячих клавиш


Переключайте два последних используемых режима отображения панели DevTools при помощи сочетания клавиш Cmd + Shift + D. Панель поддерживает следующие опции показа:
  • прикреплена к правому краю окна браузера;
  • прикреплена к нижнему краю окна браузера;
  • отображается в отдельном окне.
Посмотреть скринкаст


20. Переключение на DOM-элемент из DevTools консоли


Если в консоль выведен DOM-элемент (например, это можно сделать при помощи метода console.log), то вы можете переключиться на его представление в панели «Elements», выбрав «Reveal in Elements panel» в контекстном меню выведенного узла.
Посмотреть скринкаст


21. Подсветка выполняемого выражения


Вы можете увидеть конкретное выражение, на котором было остановлено выполнение кода: оно подсвечивается темно-голубым цветом. Это может быть полезно также при отладке минифицированного кода.
Посмотреть скринкаст


22. Улучшения в работе инструмента Color Picker


Команда разработки DevTools улучшила инструмент выбора цвета:
  • добавлен функционал захвата цвета с веб-страницы («пипетка»);
  • упростился интерфейс, позволяющий вам подобрать цвет из палитры (включая альфа-канал);
  • появилось переключение формата отображения цвета (hex, rgba, hsla).
Посмотреть скринкаст


23. Включение точки останова и навигация по стеку вызовов при помощи горячих клавиш


При работе с отладчиком вам помогут несколько клавиатурных сокращений:
  • Включение/выключение точки останова на текущей строке js-файла: Cmd + B
  • Выбор следующего фрейма в стеке вызовов: Ctrl + .
  • Выбор предыдущего фрейма в стеке вызовов: Ctrl + ,
Посмотреть скринкаст


24. Просмотр определения функции, зарегистрированной как обработчик события на DOM-элементе


Переключитесь на панель «Event Listeners» при выборе DOM-узла, и вы сможете увидеть все зарегистрированные на нем обработчики событий. Также можно посмотреть определение любого обработчика, выбрав пункт «Show Function Definition» в его контекстном меню.
Посмотреть скринкаст


25. Нотификация о JS-ошибке во время написания кода


Если вы получили ошибку в консоли, кликните на нее, чтобы переместиться к вызвавшему сбой коду в панели «Sources» (рядом с ним вы увидите иконку и текст ошибки). Если начать редактировать код, то он будет исполнен заново в реальном времени.
Посмотреть скринкаст


26. Персистентность настроек отображения для режима «Инкогнито»


Иногда гораздо удобнее заниматься отладкой в режиме «Инкогнито», потому что он не хранит ваших данных, и там по умолчанию не установлены браузерные расширения.
Теперь DevTools запоминает настройки отображения панелей (режим, размеры и т.д.) и настройки самого инструмента (отключение кеша и т.д.) и будет использовать их при открытии DevTools в режиме «Инкогнито».
Если интересны подробности, их можно прочитать здесь.
Посмотреть скринкаст


27. Визуализация выбранного режима сглаживания анимации


Если вы видите свойство, содержащее сглаживание (например, ease-in в свойстве transition: color .5s ease-in;), то для того, чтобы посмотреть на что оно похоже, кликните на иконку сглаживания. Вы также сможете попробовать другие функции сглаживания и применить подходящую к текущему элементу.
Посмотреть скринкаст


28. Просмотр и изменения точек останова DOM-дерева при помощи панели «Breakpoints»


Используйте панель точек останова DOM-дерева («Breakpoints»), чтобы включить, выключить или удалить брейкпоинты, которые вы уже поставили.
Посмотреть скринкаст


29. Пять интересных возможностей панели «Console»


  1. Выбирайте конкретный DOM-узел в панели «Elements», передав его в функцию inspect(node)
  2. Копируйте текст при помощи команды copy(text):
    copy(Object.keys(window))
    // скопирует все свойства объекта window ("top", "window", "location" и т.д.)

  3. Стилизуйте консольный вывод:
    console.log("%cHello world", "font-size:40px; color:#fff; place_your_code: here")

  4. Получайте массив значений объекта:
    values({ one: 1, two: 2, three: 3 }); // выведет [1, 2, 3]

  5. Очищайте консоль при помощи горячих клавиш Cmd + K.
Посмотреть скринкаст


30. Автодополнение свойств и методов объекта в панели «Console»


Автодополнение в консоли работает не только при использовании точки (window.onlo > window.onload), но и при использовании квадратных скобок (window['onloa > window['onload']).
Также вы можете использовать его при отладке массивов (arr[0 > arr[0]).
Посмотреть скринкаст


31. Просмотр и отладка обработчиков событий


Используйте функцию getEventListeners(node) в консоли для получения всех зарегистрированных обработчиков событий для переданного DOM-элемента. Кроме этого есть конструкция debug(fn), останавливающая исполнение программы, в момент вызова переданной функции.
Посмотреть скринкаст


32. Автоматическая остановка выполнения программы при возникновении любых исключений


Вы можете остановить поток исполнения при возникновении исключения, которое не обрабатывается вашим кодом. Для этого включите опцию «Pause on exceptions» в панели «Sources». Кроме этого вы можете поймать все обработанные исключения, установив галочку «Pause on caught exceptions».
При использовании этой функциональности у вас появится возможность выявить проблему в коде до фактического возникновения ошибки.
Посмотреть скринкаст


Дальше — больше. Stay tuned!

Комментарии (12)


  1. ReanGD
    15.10.2015 13:02
    +1

    Немного не по теме, но чем вы скринкасты записывали?


    1. Dreadatour
      15.10.2015 13:05
      +2

      Можно, например, с помощью QuickTime их записывать.


    1. xGromMx
      15.10.2015 15:20
      +3

      1. puelle
        15.10.2015 15:25
        +1

        Спасибо! И прямиком в GIF.


  1. faiwer
    15.10.2015 13:03

    Очищайте консоль при помощи горячих клавиш Cmd + K.

    Хм. А как сделать не на Mac-е? Попробовал с ctrl, alt, alt+ctrl, shift+ctrl, shift+alt. Тщетно.


    1. puelle
      15.10.2015 13:22
      +3

      Попробуйте Ctrl + L.


      1. faiwer
        15.10.2015 13:24

        Thx. Работает. Разные shortcut-ы в разных ОС. Интересно, с чего это так. С ctrl+L в браузерах я знаком по «перевести фокус в строку адреса».


        1. puelle
          15.10.2015 13:27
          +1

          Действительно интересно, с учетом того, что на маке фокус в адресную строку переводит Cmd + L.


          1. Dreadatour
            16.10.2015 15:08

            Например, в терминалах на маке (Terminal.app, iTerm) Cmd+K очищает экран.


        1. kovalevsky
          15.10.2015 13:28
          +1

          По F6 удобнее же


          1. faiwer
            15.10.2015 13:40
            +1

            Ну F6 не переводит курсор в строку адреса, к примеру, в nautilus-е. А ctrl+L переводит ;) Видимо, ctrl+L более распространённый вариант.


  1. Gurylyov
    21.10.2015 07:35

    За getEventListeners() спасибо! Давно хотел что-то подобное, а оно давно уже под носом.