Poznaj nowe procesy debugowania dzięki temu obszernemu przewodnikowi po funkcjach debugowania w Narzędziach deweloperskich w Chrome.
Aby poznać podstawy debugowania, przeczytaj artykuł Pierwsze kroki z debugowaniem JavaScriptu w Narzędziach deweloperskich w Chrome.
Wstrzymywanie kodu za pomocą punktów przerwania
Ustaw punkt przerwania, aby móc wstrzymać kod w trakcie jego wykonywania. Aby dowiedzieć się, jak ustawiać punkty przerwania, przeczytaj artykuł Wstrzymywanie kodu za pomocą punktów przerwania.
Sprawdzanie wartości w trybie wstrzymania
Podczas wstrzymania wykonywania debugger ocenia wszystkie zmienne, stałe i obiekty w bieżącej funkcji aż do punktu przerwania. Debuger wyświetla bieżące wartości w tekście obok odpowiednich deklaracji.
Za pomocą Konsoli możesz wysyłać zapytania dotyczące ocenionych zmiennych, stałych i obiektów.
Podgląd właściwości klasy lub funkcji po najechaniu kursorem
Podczas wstrzymania wykonywania najedź kursorem na nazwę klasy lub funkcji, aby wyświetlić podgląd jej właściwości.
Przeglądanie kodu
Gdy kod zostanie wstrzymany, przejdź przez niego krok po kroku, badając po drodze przepływ sterowania i wartości właściwości.
Przechodzenie przez wiersz kodu
Gdy zatrzymasz odtwarzanie na linii kodu zawierającej funkcję, która nie ma związku z rozwiązywanym problemem, kliknij Pomiń , aby wykonać funkcję bez wchodzenia w jej skład.
Załóżmy na przykład, że debugujesz ten kod:
function updateHeader() {
var day = new Date().getDay();
var name = getName(); // A
updateName(name); // D
}
function getName() {
var name = app.first + ' ' + app.last; // B
return name; // C
}
Twoje konto zostało wstrzymane A
. Po naciśnięciu Przejdź dalej, Narzędzia deweloperskie wykonają cały kod w funkcjach, które chcesz pominąć, czyli B
i C
. Narzędzia deweloperskie zostaną wstrzymane o D
.
Wczytywanie linii kodu
Gdy zatrzymasz się na wierszu kodu zawierającym wywołanie funkcji związane z rozwiązywanym problemem, kliknij Wejdź , aby dokładniej zbadać tę funkcję.
Załóżmy na przykład, że debugujesz ten kod:
function updateHeader() {
var day = new Date().getDay();
var name = getName(); // A
updateName(name);
}
function getName() {
var name = app.first + ' ' + app.last; // B
return name;
}
Twoje konto zostało wstrzymane A
. Gdy klikniesz Wejdź, Narzędzia deweloperskie wykonają ten wiersz kodu, a potem zatrzymają się na B
.
Wyjście z linii kodu
Jeśli wstrzymasz działanie w funkcji, która nie jest związana z problemami, które debugujesz, kliknij Przejdź do następnego poziomu , aby wykonać pozostałą część kodu funkcji.
Załóżmy na przykład, że debugujesz ten kod:
function updateHeader() {
var day = new Date().getDay();
var name = getName();
updateName(name); // C
}
function getName() {
var name = app.first + ' ' + app.last; // A
return name; // B
}
Twoje konto zostało wstrzymane A
. Po naciśnięciu Wyjdź narzędzia DevTools wykonają pozostałą część kodu w getName()
, która w tym przykładzie to tylko B
, a potem zatrzymają się na C
.
Uruchamianie całego kodu do określonej linii
Podczas debugowania długiej funkcji może się okazać, że zawiera ona dużo kodu, który nie ma związku z rozwiązywanym problemem.
Możesz przejrzeć wszystkie wiersze, ale może to być żmudne. Możesz ustawić punkt przerwania w linii kodu, która Cię interesuje, a potem nacisnąć Wznów wykonywanie skryptu , ale istnieje szybszy sposób.
Kliknij prawym przyciskiem myszy interesujący Cię wiersz kodu i wybierz Przejdź tutaj. Narzędzie DevTools wykonuje cały kod do tego miejsca, a potem się zatrzymuje na tej linii.
Wznów wykonywanie skryptu
Aby wznowić wykonywanie skryptu po jego wstrzymaniu, kliknij Wznów wykonywanie skryptu . DevTools wykona skrypt do następnego punktu przerwania (jeśli taki występuje).
Wymuszanie wykonywania skryptu
Aby zignorować wszystkie punkty przerwania i zmusić skrypt do wznowienia wykonywania, kliknij i przytrzymaj Wznów wykonywanie skryptu , a następnie wybierz Wykonaj skrypt na siłę .
Zmiana kontekstu wątku
Podczas pracy z procesami web worker lub service worker kliknij kontekst wymieniony na panelu Wątek, aby przełączyć się na ten kontekst. Ikona niebieskiej strzałki wskazuje, który kontekst jest obecnie wybrany.
Na powyższym zrzucie ekranu panel Wątek jest obrysowany na niebiesko.
Załóżmy na przykład, że masz zatrzymany punkt w skrypcie głównym i skrypcie usługi. Chcesz wyświetlić właściwości lokalne i globalne w kontekście usługi, ale panel Źródła pokazuje główny kontekst skryptu. Klikając wpis dotyczący serwisu workera w panelu Wątek, możesz przełączyć się do tego kontekstu.
Przechodzenie przez wyrażenia rozdzielone przecinkami
Przechodzenie przez wyrażenia rozdzielone przecinkami umożliwia debugowanie zminifikowanego kodu. Weźmy na przykład ten kod:
function foo() {}
function bar() {
foo();
foo();
return 42;
}
bar();
Po zwinifikowaniu zawiera rozdzielone przecinkami wyrażenie foo(),foo(),42
:
function foo(){}function bar(){return foo(),foo(),42}bar();
Debuger przetwarza takie wyrażenia w taki sam sposób.
Dlatego sposób działania jest identyczny:
- Pomiędzy zminiaturyzowanym a autorskim kodem.
- Gdy używasz map źródeł do debugowania zminifikowanego kodu w powiązaniu z oryginalnym kodem. Innymi słowy, gdy widzisz średniki, możesz zawsze oczekiwać, że będziesz je przechodzić, nawet jeśli rzeczywiste źródło, które debugujesz, jest zminiaturyzowane.
Wyświetlanie i edytowanie właściwości lokalnych, zamkniętych i globalnych
Gdy zatrzymasz kursor na linii kodu, możesz użyć panelu Zakres, aby wyświetlić i zmodyfikować wartości właściwości i zmiennych w zakresie lokalnym, zamkniętym i globalnym.
- Aby zmienić wartość właściwości, kliknij ją dwukrotnie.
- Właściwości, których nie można wylistować, są wyszarzone.
Na powyższym zrzucie ekranu panel Zakres jest obrysowany na niebiesko.
Wyświetlanie bieżącego stosu wywołań
Gdy zatrzymasz kursor na wierszu kodu, możesz wyświetlić panel zbiór wywołań, aby zobaczyć zbiór wywołań, który doprowadził do tego punktu.
Kliknij wpis, aby przejść do wiersza kodu, w którym została wywołana dana funkcja. Niebieska strzałka wskazuje, która funkcja jest obecnie wyróżniana w DevTools.
Na powyższym zrzucie ekranu panel Zbiór wywołań jest obrysowany na niebiesko.
Ponowne uruchamianie funkcji (ramki) w stosie wywołań
Aby obserwować działanie funkcji i ponowić jej wykonywanie bez konieczności ponownego uruchamiania całego procesu debugowania, możesz wznowić wykonywanie pojedynczej funkcji, gdy jest ona wstrzymana. Innymi słowy, możesz ponownie uruchomić ramkę funkcji w stosie wywołań.
Aby ponownie uruchomić ramkę:
- Wstrzymaj wykonywanie funkcji w punkcie przerwania. Panel Stos wywołań rejestruje kolejność wywołań funkcji.
W panelu Stos wywołania kliknij prawym przyciskiem myszy funkcję i w menu kliknij Restart frame (Uruchom ponownie ramkę).
Aby zrozumieć, jak działa ramka Restart, rozważ użycie tego kodu:
function foo(value) {
console.log(value);
bar(value);
}
function bar(value) {
value++;
console.log(value);
debugger;
}
foo(0);
Funkcja foo()
przyjmuje jako argument funkcję 0
, rejestruje ją i wywołuje funkcję bar()
. Funkcja bar()
zwiększa argument.
Spróbuj ponownie utworzyć ramki obu funkcji w ten sposób:
- Skopiuj kod powyżej do nowego fragmentu kodu i go uruchom. Wykonywanie zostaje zatrzymane w punkcie przerwania w kodzie
debugger
. - Zauważ, że debuger obok deklaracji funkcji
value = 1
pokazuje bieżącą wartość. - Ponownie uruchom ramkę
bar()
. - Aby przejść do instrukcji zwiększania wartości, naciśnij
F9
. Zauważysz, że bieżąca wartość rośnie:value = 2
. - Opcjonalnie w panelu Zakres kliknij dwukrotnie wartość, aby ją edytować i ustawić odpowiednią wartość.
Spróbuj ponownie uruchomić ramkę
bar()
i kilka razy przejść przez instrukcję zwiększania. Wartość stale rośnie.
Ponowna inicjalizacja ramki nie powoduje zresetowania argumentów. Inaczej mówiąc, ponowne uruchomienie nie przywraca początkowego stanu w przypadku wywołania funkcji. Zamiast tego przenosi ona wskaźnik wykonania do początku funkcji.
Dlatego bieżąca wartość argumentu jest przechowywana w pamięci podczas ponownego uruchamiania tej samej funkcji.
- Teraz ponownie uruchom ramkę
foo()
w sekcji Stos wywołań. Zwróć uwagę, że wartość znowu wynosi0
.
W JavaScript zmiany argumentów nie są widoczne (nie są odzwierciedlane) poza funkcją. Funkcje zagnieżdżone otrzymują wartości, a nie ich lokalizację w pamięci.
1. Aby ukończyć samouczek, wznów wykonywanie skryptu (F8
).
Pokaż ramki z listy ignorowanych
Domyślnie panel Stos wywołania zawiera tylko ramki istotne dla Twojego kodu i pomija skrypty dodane do Ustawień > Listy ignorowanych.
Aby wyświetlić pełny zrzut stosu wywołania, w tym ramki zewnętrzne, w sekcji Zrzut stosu wywołania włącz opcję Pokaż ramki z listy ignorowanych.
Wypróbuj to na stronie demonstracyjnej:
- W panelu Źródła otwórz plik
src
>app
>app.component.ts
. - Ustaw punkt przerwania w funkcji
increment()
. - W sekcji Ramka wywołania zaznacz lub odznacz pole wyboru Pokaż klatki na liście ignorowanych i obserwuj odpowiednią lub pełną listę klatek w ramce wywołania.
Wyświetlanie ramek asynchronicznych
Jeśli używana przez Ciebie platforma obsługuje to, DevTools może śledzić operacje asynchroniczne, łącząc ze sobą obie części kodu asynchronicznego.
W tym przypadku zbiór wywołań zawiera całą historię wywołań, w tym ramki wywołań asynchronicznych.
Kopiowanie zrzutu stosu
Kliknij prawym przyciskiem myszy dowolne miejsce w panelu Stos wywołań i wybierz Kopiuj ścieżkę wywołań, aby skopiować bieżący stos wywołań do schowka.
Oto przykład danych wyjściowych:
getNumber1 (get-started.js:35)
inputsAreEmpty (get-started.js:22)
onClick (get-started.js:15)
Poruszanie się po drzewie plików
Do poruszania się po drzewie plików służy panel Strona.
Grupowanie w drzewie plików utworzonych i wdrożonych plików
Podczas tworzenia aplikacji internetowych za pomocą frameworków (np. React lub Angular) może być trudno poruszać się po źródłach ze względu na zminiaturyzowane pliki wygenerowane przez narzędzia do kompilacji (np. webpack lub Vite).
Aby ułatwić Ci poruszanie się po źródłach, panel Źródła > Strona może grupować pliki w 2 kategorie:
- Autor. Podobnie jak pliki źródłowe w Twoim środowisku IDE. Narzędzia deweloperskie generują te pliki na podstawie map źródeł udostępnionych przez narzędzia do kompilacji.
- Wdrożony. Rzeczywiste pliki odczytywane przez przeglądarkę. Zwykle są one zminifikowane.
Aby włączyć grupowanie, w menu z 3 kropkami u góry drzewa plików włącz opcję > Grupuj pliki według autora lub wersji .
Ukrywanie źródeł z listy ignorowanych w drzewie plików
Aby ułatwić Ci skupienie się tylko na tworzonym kodzie, panel Źródła > Strona domyślnie przyciemnia wszystkie skrypty lub katalogi dodane do Ustawień > Listy ignorowania.
Aby ukryć takie skrypty, wybierz Źródła > Strona > > Ukryj źródła na liście ignorowanych .
Ignorowanie skryptu lub wzorca skryptów
Ignorowanie skryptu, aby go pominąć podczas debugowania. Ignorowany skrypt jest zaciemniony w panelu zbiór wywołań, a podczas przechodzenia po kodzie nigdy nie wchodzisz do jego funkcji.
Załóżmy, że analizujesz ten kod:
function animate() {
prepare();
lib.doFancyStuff(); // A
render();
}
A
to biblioteka innej firmy, której ufasz. Jeśli masz pewność, że problem, który debugujesz, nie jest związany z biblioteką zewnętrzną, możesz zignorować skrypt.
Ignorowanie skryptu lub katalogu w drzewie plików
Aby zignorować pojedynczy skrypt lub cały katalog:
- W sekcji Źródła > Strona kliknij prawym przyciskiem katalog lub plik skryptu.
- Wybierz Dodaj katalog lub skrypt do listy ignorowanych.
Jeśli nie ukryjesz źródła na liście ignorowanych, możesz je wybrać w drzewie plików, a na banerze kliknąć Usuń z listy ignorowanych lub Skonfiguruj.
Możesz też usunąć ukryte i ignorowane katalogi oraz skrypty z listy w sekcji Ustawienia > Lista ignorowania.
Ignorowanie skryptu w panelu Edytor
Aby zignorować skrypt w panelu Edytor:
- Otwórz plik.
- Kliknij prawym przyciskiem myszy dowolne miejsce.
- Wybierz Dodaj skrypt do listy ignorowanych fragmentów kodu.
Skrypt można usunąć z listy ignorowanych, klikając Ustawienia > Lista ignorowanych.
Ignorowanie skryptu w panelu Stos wywołania
Aby zignorować skrypt w panelu Stos wywołania:
- Kliknij prawym przyciskiem myszy funkcję w skrypcie.
- Wybierz Dodaj skrypt do listy ignorowanych fragmentów kodu.
Skrypt można usunąć z listy ignorowanych, klikając Ustawienia > Lista ignorowanych.
Ignorowanie skryptu w Ustawieniach
Zobacz Ustawienia > Lista ignorowanych.
uruchamiać fragmenty kodu debugującego z dowolnej strony.
Jeśli zauważysz, że w konsoli ciągle uruchamiasz ten sam kod debugowania, rozważ użycie fragmentów kodu. Fragmenty kodu to skrypty do wykonania, które tworzysz, przechowujesz i uruchamiasz w Narzędziach deweloperskich.
Więcej informacji znajdziesz w artykule Uruchamianie fragmentów kodu z dowolnej strony.
Obserwowanie wartości niestandardowych wyrażeń JavaScript
Wartości wyrażeń niestandardowych możesz sprawdzać w panelu Obserwowanie. Możesz obejrzeć dowolne poprawne wyrażenie JavaScript.
- Aby utworzyć nowe wyrażenie dotyczące oglądania, kliknij Dodaj wyrażenie.
- Aby odświeżyć wartości wszystkich istniejących wyrażeń, kliknij Odśwież . Wartości są automatycznie odświeżane podczas przechodzenia przez kod.
- Najedź kursorem na wyrażenie i kliknij Usuń wyrażenie , aby je usunąć.
Sprawdzanie i edytowanie skryptów
Gdy otworzysz skrypt w panelu Strona, DevTools wyświetli jego zawartość w panelu Edytor. W panelu Edytor możesz przeglądać i edytować kod.
Dodatkowo możesz zastąpić zawartość lokalnie lub utworzyć obszar roboczy i zapisać zmiany wprowadzone w Narzędziach deweloperskich bezpośrednio w źródłach lokalnych.
Ustawianie zminifikowanego pliku jako czytelny
Domyślnie panel Źródła formatuje stylistycznie zminifikowane pliki. W trybie drukowania Edytor może wyświetlić jedną długą linię kodu na kilku wierszach, a -
wskazuje, że jest to kontynuacja linii.
Aby zobaczyć zminiaturyzowany plik w postaci, w której został załadowany, w lewym dolnym rogu Edytora kliknij { }
.
Zwijanie bloków kodu
Aby zwinąć blok kodu, najedź kursorem na numer wiersza w lewym słupie i kliknij Zwiń.
Aby rozwinąć blok kodu, kliknij {...}
obok niego.
Aby skonfigurować to działanie, kliknij Ustawienia > Ustawienia > Źródła.
Edytowanie skryptu
Podczas usuwania błędu często trzeba przetestować zmiany w kodzie JavaScript. Nie musisz wprowadzać zmian w zewnętrznej przeglądarce, a potem ponownie wczytywać strony. Skrypt możesz edytować w DevTools.
Aby edytować skrypt:
- Otwórz plik w panelu Edytor w panelu Źródła.
- Wprowadź zmiany w panelu Edytor.
Aby zapisać, naciśnij Command + S (Mac) lub Ctrl + S (Windows, Linux). Narzędzia deweloperskie wstawiają cały plik JS do mechanizmu JavaScriptu w Chrome.
Na powyższym zrzucie ekranu panel Edytor jest obrysowany na niebiesko.
Edytowanie funkcji wstrzymanej na żywo
Podczas wstrzymania wykonywania możesz edytować bieżącą funkcję i stosować zmiany na żywo z tymi ograniczeniami:
- Możesz edytować tylko funkcję najwyższego poziomu w zbiorze wywołań.
- W dalszej części stosu nie może być wywołań rekurencyjnych tej samej funkcji.
Aby edytować funkcję na żywo:
- Wstrzymaj wykonywanie za pomocą punktu przerwania.
- Zmodyfikuj wstrzymaną funkcję.
- Aby zastosować zmiany, naciśnij Command lub Control + S. Debuger ponownie uruchamia funkcję automatycznie.
- Kontynuuj wykonywanie.
Aby dowiedzieć się więcej o tym procesie, obejrzyj film poniżej.
W tym przykładzie zmienne addend1
i addend2
mają początkowo nieprawidłowy typ string
. Zamiast dodawania liczb, ciągi znaków są łączone. Aby rozwiązać ten problem, funkcje parseInt()
są dodawane podczas edycji na żywo.
Wyszukiwanie i zastępowanie tekstu w skrypcie
Aby wyszukać tekst w skrypcie:
- Otwórz plik w panelu Edytor w panelu Źródła.
- Aby otworzyć wbudowany pasek wyszukiwania, naciśnij Command + F (Mac) lub Ctrl + F (Windows, Linux).
- Na pasku wpisz zapytanie.
Opcjonalnie możesz:
- Aby zapytanie uwzględniało wielkość liter, kliknij Zgodność wielkości liter.
- Aby wyszukać za pomocą wyrażenia regularnego, kliknij Użyj wyrażenia regularnego.
- Naciśnij Enter. Aby przejść do poprzedniego lub następnego wyniku wyszukiwania, naciśnij przycisk w górę lub w dół.
Aby zastąpić znaleziony tekst:
- Na pasku wyszukiwania kliknij przycisk Zastąp.
- Wpisz tekst, który ma zastąpić wybrany fragment, a potem kliknij Zamień lub Zamień wszystko.
Wyłącz JavaScript
Zobacz artykuł Wyłączanie JavaScriptu za pomocą Narzędzi deweloperskich w Chrome.