Jak ustawić punkt przerwania JavaScript z kodu w Chrome?
Chcę zmusić debugera Chrome do złamania w linii za pomocą kodu , lub użyć jakiegoś znacznika komentarza, takiego jak coś w stylu console.break()
.
10 answers
Możesz użyć debugger;
w swoim kodzie. Jeśli konsola programisty jest otwarta, wykonanie zostanie przerwane. Działa również w firebug.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-04-06 23:49:37
Ustaw przycisk kliknij listener i wywołaj debugger;
Przykład
$("#myBtn").click(function() {
debugger;
});
Demo
Resources on debugging in JavaScript
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-05-04 17:33:09
Jak już powiedzieli inni, debugger;
jest droga do zrobienia.
Napisałem mały skrypt, który możesz użyć z wiersza poleceń w przeglądarce, aby ustawić i usunąć punkt przerwania tuż przed wywołaniem funkcji:
http://andrijac.github.io/blog/2014/01/31/javascript-breakpoint/
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-03-07 19:22:54
Możesz również użyć debug(function)
, aby złamać, gdy wywołane jest function
.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-08-19 11:00:51
W zakładce "Skrypty" przejdź do miejsca, w którym znajduje się Twój kod. Po lewej stronie numeru linii kliknij. Spowoduje to ustawienie punktu przerwania.
Zrzut ekranu:
Będziesz mógł śledzić swoje punkty przerwania na prawej karcie (jak pokazano na zrzucie ekranu).
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-04-06 23:53:28
debugger
jest zastrzeżonym słowem kluczowym EcmaScript i podanym opcjonalną semantyką od ES5
W rezultacie może być używany nie tylko w Chrome, ale także Firefox i Node.JS via node debug myscript.js
.
Norma mówi :
Składnia
DebuggerStatement : debugger ;
Semantyka
Ocena produkcji DebuggerStatement może pozwolić implementacji na wywołanie punktu przerwania, gdy zostanie uruchomiona pod debuggerem. Jeśli debugger nie jest obecny lub aktywny to polecenie nie ma widocznego efektu.
Production DebuggerStatement: debugger; jest oceniany w następujący sposób:
- Jeśli implementacja defined debugging facility jest dostępna i włączona, To
- wykonaj operację debugowania zdefiniowaną w implementacji.
- niech wynik będzie wartością zakończenia zdefiniowaną w implementacji.
- Else
- niech wynik będzie (normalny, pusty, pusty).
- Return result.
Brak zmian w ES6.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-05-05 09:50:06
Jest to możliwe i jest wiele powodów, dla których warto to zrobić. Na przykład debugowanie nieskończonej pętli javascript blisko początku ładowania strony, która uniemożliwia prawidłowe ładowanie zestawu narzędzi programistycznych chrome (lub firebug).
Patrz punkt 2
Http://www.laurencegellert.com/2012/05/the-three-ways-of-setting-breakpoints-in-javascript/
Lub po prostu dodaj linię zawierającą słowo debugger do kodu w wymaganym punkcie testowym.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-01-21 10:02:20
Breakpoint:-
Breakpoint przestanie być wykonywany i pozwoli Ci zbadać wartości JavaScript.
Po sprawdzeniu wartości można wznowić wykonywanie kodu (zazwyczaj za pomocą przycisku play).
Debugger : -
Debugger; zatrzymuje wykonywanie JavaScript i wywołuje funkcję debugowania.
Instrukcja debugger zawiesza wykonywanie, ale nie zamyka żadnych plików ani nie usuwa żadnych zmiennych.
Example:-
function checkBuggyStuff() {
debugger; // do buggy stuff to examine.
};
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-11-04 18:06:07
Można również ustawić debug(functionName)
do debugowania funkcji.
Https://developers.google.com/web/tools/chrome-devtools/javascript/breakpoints#function
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-01-19 10:37:56
Istnieje wiele sposobów debugowania kodu JavaScript. Następujące dwa podejścia są szeroko stosowane do debugowania JavaScript za pomocą kodu
-
Użycie
console.log()
do wydruku wartości w przeglądarce konsola. (Pomoże Ci to zrozumieć wartości w określonych punktach Twojego kodu) Słowo kluczowe debuggera. Dodaj
debugger;
do lokalizacji, które chcesz Debuguj, otwórz konsolę dewelopera przeglądarki i przejdź do zakładka źródła.
Aby uzyskać więcej narzędzi i sposobów, w których debug JavaScript kod, podane są w ten link przez W3School.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-04-26 14:18:35