• Главная
  • Контакты
Подписаться:
  • Twitter
  • Facebook
  • RSS
  • VK
  • PushAll
logo

logo

  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • За год
    • Положительные
    • Отрицательные
  • Сортировка
    • По дате (возр)
    • По дате (убыв)
    • По рейтингу (возр)
    • По рейтингу (убыв)
    • По комментам (возр)
    • По комментам (убыв)
    • По просмотрам (возр)
    • По просмотрам (убыв)
Главная
  • Все
    • Положительные
    • Отрицательные
  • За сегодня
    • Положительные
    • Отрицательные
  • За вчера
    • Положительные
    • Отрицательные
  • За 3 дня
    • Положительные
    • Отрицательные
  • За неделю
    • Положительные
    • Отрицательные
  • За месяц
    • Положительные
    • Отрицательные
  • Главная
  • Способы отладки JS на клиенте

Способы отладки JS на клиенте +11

23.04.2017 18:21
comerc 20 6400 Источник
Разработка веб-сайтов*, ReactJS*, JavaScript*

Применительно к разработке на create-react-app (CRA) в браузере и в IDE WebStorm. Если вам известны какие-либо другие способы отладки, большая просьба поделиться знаниями.


Отладка внутри Chrome


После запуска приложения в браузере, нажмите [F12], чтобы открыть Chrome DevTools, потом переключитесь на вкладку Sources, нажмите [Ctrl+P], в строке поиска введите имя требуемого файла.



 
Благодаря Source Map, мы видим исходный JSX. Далее можно отметить нужную строчку кода, как точку останова, затем перегрузить страницу по [F5], и получить желаемое — инструмент отладки.



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



 
Иногда хочется отлаживать по старинке, с помощью console.log(). Можно получить значение переменной внутри JSX прямо в точке её применения.


<img src={console.log('logo', logo) || logo} />

Как это работает: console.log() вернет undefined и код выполнится дальше по условию "||", а в консоли браузера мы увидим искомое значение, например: "/static/media/logo.5d5d9eef.svg".


Отладка внутри IDE WebStorm


Используется последняя версия 2017.1. Сначала нужно настроить окружение. Установите расширение Chrome — JetBrains IDE Support. Затем добавьте Run/Debug-конфигурацию.



 
Запустите CRA обычным образом, выполнив в терминале:


$ yarn start

Выберите конфигурацию Debug и нажмите кнопку с иконкой жука (в правом верхнем углу IDE):



 
Откроется браузер с предупреждением "JetBrains IDE Support отлаживает этот браузер". (Замечено, что если теперь открыть Chrome DevTools по [F12], то отладка в WebStorm завершится — не надо этого делать). Далее можно отметить нужную строчку кода, как точку останова, затем перегрузить страницу браузера по [F5], и получить желаемое — инструмент отладки внутри WebStorm.



 
Отладка тестов требует дополнительной настройки, потому как этот код не запускается в браузере. Установите глобально пакеты:


$ npm install -g babel-cli babel-preset-es2015

Затем добавьте ещё одну Run/Debug-конфигурацию.



 
Выберите конфигурацию Tests и нажмите кнопку с иконкой жука:



 
Ура, нам доступна отладка тестов.


Поделиться с друзьями
-->

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


  1. SbWereWolf
    23.04.2017 22:40
    #10187746
    +1

    большое спасибо за туториал


  1. aon24
    23.04.2017 22:47
    #10187754
    +1

    Полезная информация.
    Вопрос к знатокам npm:
    существует ли возможность, работая в среде create-react-app, обращаться к другому серверу ( не localhost:3000) за реальными данными?
    Если нет, еще вопрос:
    можно ли в среде create-react-app создать не минимизированную версию?
    Что-то типа «npm run build», но чтобы потом можно было отлаживать.


    1. comerc
      23.04.2017 22:59
      #10187764
      +1

      существует ли возможность, работая в среде create-react-app, обращаться к другому серверу ( не localhost:3000) за реальными данными?

      Конечно. Посмотрите на мой фан-проект. Сервер живет по адресу localhost:9000 и разрешает обращаться к себе всем (Access-Control-Allow-Origin)


    1. vilozio
      24.04.2017 09:29
      #10188060
      +2

      В create-react-app используется webpack-dev-server, с ним можно перенаправлять запросы через proxy на бэкэнд сервер:
      https://webpack.js.org/configuration/dev-server/#devserver-proxy


      1. comerc
        24.04.2017 09:45
        #10188086

        Я использую axios для всех RESTful-запросов, определил в конфиге baseURL: https://github.com/mzabriskie/axios#request-config


        1. Tihon_V
          24.04.2017 10:31
          #10188140
          +1

          Я использую docker-контейнер с nginx в качестве прокси.

          Кусочек конфига
          if ($request_method = OPTIONS ) {
          add_header Access-Control-Allow-Origin "*";
          add_header Access-Control-Allow-Methods "GET, PUT, POST, DELETE, HEAD, OPTIONS";
          add_header Access-Control-Allow-Headers "Authorization";
          add_header Access-Control-Allow-Credentials "true";
          add_header Content-Length 0;
          add_header Content-Type text/plain;
          return 200;
          }


    1. justboris
      24.04.2017 10:28
      #10188132
      +1

      В Readme есть официальный способ.


      Добавляете в package.json секцию proxy, и все запросы, не возвращающие файлы, будут проксироваться на указанный адрес.


      Позволяет обойтись без дополнительной настройки cors, который может быть запрещен требованиями безопасности.


    1. justboris
      24.04.2017 10:29
      #10188136

      можно ли в среде create-react-app создать не минимизированную версию? Что-то типа «npm run build», но чтобы потом можно было отлаживать.

      А что не так с npm start?


  1. LastDragon
    24.04.2017 09:08
    #10188024
    +3

    Visual Studio 2017 прямо из коробки умеет аналогично JetBrains-у, только ставить вообще ничего не надо (2015 так-то тоже умеет, но нигде кроме IE оно у меня не заработало), единственное, консолька в самом браузере сильно удобнее чем в студии.


    1. comerc
      24.04.2017 09:51
      #10188096
      -3

      Отладка внутри WebStorm выигрывает против отладки в браузере.


      1. vba
        24.04.2017 11:50
        #10188286
        +1

        Отладка JS во всех продуктах JetBrains ужасно тормозит, точнее не сама отладка а обновление состояния переменных из шага в шаг. Да и что там выигрывает, не понятно, в браузере функционал даже побогаче будет.


        1. comerc
          24.04.2017 12:49
          #10188386

          Про всех не скажу, но WebStorm версии 2017.1 работает нормально. При том, что у меня не самая мощная машина на свете.


          Расстраивают тормоза Resolving Reference после перехода на Flow. Инспекцию по ESLint внутри WebStorm отключил — тоже тормозит, и в CRA прекрасно настроен вывод сообщений ESLint.


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


  1. NafFiQ
    24.04.2017 09:28
    #10188052
    +1

    Спасибо за статью.
    Возник такой вопрос: как интегрировать тесты в create-react-app на jest с webstorm без команды eject?


    1. comerc
      24.04.2017 09:48
      #10188090

      Вы про запуск каждого теста по кнопке play напротив декларации теста в коде? Этого не пробовал еще настроить.


      1. NafFiQ
        24.04.2017 10:40
        #10188154
        +1

        Именно, ранее запускал тесты на karma.js в webstorm и понравилась подсветка сломанных тестов и быстрый переход. Очень помогает с рефакторингом.

        Поделитесь, как получится :)


  1. hamMElion
    24.04.2017 09:35
    #10188076
    +2

    Есть небольшое расширение для Chrome React Dev Tools — дополнительная вкладка Dev Tools Chrome. С ним отладка компонентов реакта в браузере становится сильно удобнее.
    А если вы решили использовать SPOT в виде Redux, то еще могу посоветовать вот это мега-расширение


    1. comerc
      24.04.2017 12:53
      #10188396

      Расшифруйте аббревиатуру SPOT, пожалуйста.


      1. hamMElion
        24.04.2017 22:36
        #10189352
        +2

        Впервые я эту аббревиатуру услышал от коллег-немцев, мне ее расшифровали как Single Point of Truth. А в англоговорящей среде это SSOT — Single source of truth. По-моему, не так красиво звучит, как SPOT, ну как уж где привыкли.


  1. Chaptykov
    24.04.2017 19:57
    #10189120
    +1

    Любопытно, что статья называется «Способы отладки JS на клиенте», а второй абзац уже начинается с «мы видим исходный JSX», вторая часть статьи называется «Отладка внутри IDE WebStorm».


    Так что из первой части получаем, что отлаживаем не совсем JS, а из второй, что не совсем на клиенте.


    1. comerc
      25.04.2017 10:24
      #10189776

      Палка о двух концах. Способы отладки клиентского JS — как-то не очень звучит.

МЕТКИ

  • Хабы
  • Теги

Разработка веб-сайтов

ReactJS

JavaScript

вискас

СЕРВИСЫ
  • logo

    CloudLogs.ru - Облачное логирование

    • Храните логи вашего сервиса или приложения в облаке. Удобно просматривайте и анализируйте их.
Все публикации автора
  • Или Meteor +3

    • 02.08.2017 12:00

    10 шагов настройки Create React App + TypeScript + Ant-Design +7

    • 31.07.2017 16:00

    Redux Business Logic +7

    • 02.07.2017 21:25

    Интеграция React и DataTables — не так тяжело, как рекламируют +8

    • 10.06.2017 14:30

    Перевод доклада про mobx-state-tree — всё лучшее из миров Redux и MobX +4

    • 22.05.2017 10:50

    Почему программисты не могут программировать +12

    • 17.05.2017 09:02

    2017: Автостопом по галактике JavaScript +41

    • 13.05.2017 18:00

    Быстрый старт на React Native +6

    • 01.05.2017 02:01

    Загрузка данных из REST API +10

    • 26.04.2017 10:10

    Способы отладки JS на клиенте +11

    • 23.04.2017 18:21

Подписка


ЛУЧШЕЕ

  • Сегодня
  • Вчера
  • Позавчера
05:47

Треть новых релизов на Яндекс Музыке – ИИ. Теперь точно +9

07:05

От пламени прошлого — до сверхсовременных дальнобойных фонарей: история света, часть-1 +8

07:02

Опенсорсим YaGS Plugin: открытый плагин для работы с 3DGS внутри Unreal Engine +8

07:15

Как я стал туалетным сомелье +6

07:00

10–15 багов в месяц превратились в 200–300 — а кому их фиксить? +6

04:01

Локальная большая лингвистическая модель на Windows 11: выбор среды, модели и пошаговое развёртывание +5

06:24

Почему я выкинул MCP из AI-агента для CAD: граф API, ГОСТы, компилятор и live COM для KOMPAS-3D +4

02:27

Как мы делаем онлайн-режим для браузерной инди-игры, когда бюджет на сервера — $10 в месяц +4

07:53

Релизь себя бережно +3

06:43

(Не) безопасный дайджест: месть ИТ-специалиста, потерянные данные и секреты гигантов в открытом доступе +3

06:09

PID Toolkit — браузерный инструмент для настройки PID — регуляторов без установки +3

07:13

Тени истории: от глиняных табличек к Bitcoin. Как криптография создала наш цифровой мир +2

06:06

ТОП лучших планировщиков задач в Ру-сегменте +2

07:39

Шесть основ бизнес-анализа: переход из «сегодня» в «завтра» и почему сопротивление убивает даже гениальные решения +1

07:00

ИИ как часть инженерной культуры: исследуем глубину внедрения +1

06:50

Плагины в Go-автотестах: как вынести инфраструктуру за пределы тестов +1

19:18

Худший язык программирования всех времён /s +117

06:52

Работодатели давно играют в волков. Просто теперь соискатели научились отвечать +53

07:00

Нейро сети для самых маленьких. Часть первая (которая после нулевой). Удобство в прокрустовом ложе оптимизации +40

09:40

Как вайбкодинг довел меня до депрессии, а потом привел к вайб‑инжинирингу +36

07:52

«Гражданин, обновитесь»: анализ вредоносной кампании Falcon +35

08:30

Хватит прятать ключи под ковром: переносим их в облачный сервис управления ключами (KMS) +32

08:11

Не только красные и синие — новые серверные процессоры от Qualcomm и Hygon +30

07:00

Сегментация опухолей головного мозга на МРТ-снимках с акцентом на точность границы +30

12:44

Охота за районами: как устроены мобильные активации радиолюбителей +28

11:01

Как установить Hermes на VPS. Один из лучших агентов в 2026 году +25

07:06

Клод Шеннон. Информатика на максималках +24

13:01

10 «сам виноват» в карьере +22

07:01

Автомобильные сигнализации РФ и их безопасность. Часть 1 +22

07:35

Контекстная инженерия для слабой локальной модели: как мы делаем среднюю модель надёжной +19

06:31

Лучший способ изучить разработку с Qt +19

08:00

Кастомизация Битрикс24 на платформе Вайбкод: создаём паспорт клиента +18

14:57

Книга «PostgreSQL 18 изнутри»: архитектура «слона» под новым капотом +17

10:51

Обязана ли природа подчиняться законам? +16

08:49

Не Bluetooth, а Wi-Fi: третья версия моей мощной портативной Hi-Fi акустики +16

12:00

Как создавали нейропоиск Discovery AI — технологию для крупнейшей контентной базы в РФ +15

08:32

Что такое парадокс изогнутой трубы — и почему интуиция нас подводит +181

10:05

Почему я ухожу из Timeweb Cloud: 46 часов простоя в Амстердаме за два месяца — по данным самого хостера +99

12:30

Passkey без Apple, Google и облаков: делаем собственный аппаратный ключ за 4 евро +65

18:44

PostgreSQL для бэкендера: 10 фич, которыми мало пользуются, а зря +62

12:00

Пузырь ИИ лопнул? Бизнес отказывается от ChatGPT, а Microsoft пытается спасти положение софтом: ML-дайджест +60

09:02

Почему cron — самый опасный инструмент в Linux +47

07:01

Шахматная память: как гроссмейстеры запоминают тысячи партий и почему это не мнемотехника +41

13:01

Flappy Bird: делаем игру сложнее и добавляем автопилот на чистой математике +35

07:03

Почтовый ящик пандоры. Какие сервисы работают с внешними почтовыми клиентами в России в 2026 году +35

14:42

Почему сгорел Нотр-Дам: человеческий фактор, SHERPA и HTA в UX-проектировании интерфейса +30

07:05

kafkactl — другой взгляд на работу с Kafka +29

07:04

Умеют ли трансформеры водить машину +29

17:57

Антенный ротатор на PTZ 3050DZ +28

09:17

Почему опасно покупать Intel Core i7 и i9 с рук: разбираемся с деградацией процессоров 13900K и 14900K +24

09:09

Проектируем с нуля калькулятор на FPGA. Часть 6: CPU +23

20:09

Как я превратил OnePlus 3T в домашний сервер на базе postmarketOS +21

08:01

Распределённый монолит: как одну проблему превратить в целый кластер проблем +21

14:27

Я больше не объясняю нейросети контекст. Вот что я сделал вместо этого… +19

06:32

Как оценивать LLM на практике, если времени на «идеальный бенчмарк» нет +18

10:26

Я декомпилировал свою зависимость: как программист раскидал курение на 100+ субличностей и перестал курить +17

ОБСУЖДАЕМОЕ

  • Кажется я выяснил кто открыл Америку -8

    • 185   12000

    Почему я ухожу из Timeweb Cloud: 46 часов простоя в Амстердаме за два месяца — по данным самого хостера +99

    • 175   24000

    Что такое парадокс изогнутой трубы — и почему интуиция нас подводит +181

    • 117   29000

    IT-пузырь лопнул: почему одни айтишники не могут найти работу, а других всё равно не хватает -15

    • 65   23000

    Работодатели давно играют в волков. Просто теперь соискатели научились отвечать +53

    • 43   10000

    Худший язык программирования всех времён /s +117

    • 42   18000

    Почтовый ящик пандоры. Какие сервисы работают с внешними почтовыми клиентами в России в 2026 году +35

    • 41   10000

    Почему Минобрнауки боится ИИ и правда ли, что дипломные работы утратили смысл? +10

    • 39   13000

    Как Timeweb затыкает рот клиентам: история одного бана и уроки репутации +12

    • 37   7300

    Почему «удалёнка» съедает ROI компании: расчёты потерь -4

    • 37   13000

    Как вайбкодинг довел меня до депрессии, а потом привел к вайб‑инжинирингу +36

    • 36   11000

    Passkey без Apple, Google и облаков: делаем собственный аппаратный ключ за 4 евро +65

    • 34   16000

    Пузырь ИИ лопнул? Бизнес отказывается от ChatGPT, а Microsoft пытается спасти положение софтом: ML-дайджест +60

    • 33   17000

    Как я превратил OnePlus 3T в домашний сервер на базе postmarketOS +21

    • 32   14000

    ГдеЗаправка: умный подбор + как нас за сутки посетило полмиллиона +8

    • 27   13000
  • Главная
  • Контакты
© 2026. Все публикации принадлежат авторам.