חומר עזר לניפוי באגים ב-JavaScript

Sofia Emelianova
Sofia Emelianova

במסמך העזרה הזה מפורטות תכונות ניפוי הבאגים של כלי הפיתוח ל-Chrome, שיעזרו לכם לפתח תהליכי עבודה חדשים לניפוי באגים.

במאמר תחילת העבודה עם ניפוי באגים ב-JavaScript ב-Chrome DevTools מוסבר על העקרונות הבסיסיים של ניפוי באגים.

השהיה של קוד באמצעות נקודות עצירה

מגדירים נקודת עצירה כדי שתוכלו להשהות את הקוד באמצע הביצוע שלו. במאמר השהיית הקוד באמצעות נקודות עצירה מוסבר איך מגדירים נקודות עצירה.

בדיקת ערכים במצב מושהה

בזמן ההשהיה של הביצוע, מנתח הבאגים מעריך את כל המשתנים, הקבועים והאובייקטים בפונקציה הנוכחית עד לנקודת העצירה. בכלי לניפוי הבאגים מוצגים הערכים הנוכחיים בתוך השורה לצד ההצהרות המתאימות.

הערכות מוטמעות שמוצגות לצד ההצהרות.

אפשר להשתמש במסוף כדי לשלוח שאילתות לגבי המשתנים, הקבועים והאובייקטים שהועברו הערכה.

שימוש במסוף כדי לשלוח שאילתות לגבי המשתנים, הקבועים והאובייקטים שהועברו להערכה.

תצוגה מקדימה של מאפייני הכיתה/הפונקציה במעבר העכבר

כשהביצוע מושהה, מעבירים את העכבר מעל שם של סיווג או פונקציה כדי לראות תצוגה מקדימה של המאפיינים שלו.

תצוגה מקדימה של מאפייני הכיתה/הפונקציה במעבר העכבר

בדיקה של הקוד שלב אחרי שלב

אחרי שהקוד מושהה, בודקים אותו, ביטוי אחד בכל פעם, ובודקים את זרימת הבקרה ואת ערכי המאפיינים לאורך הדרך.

דילוג על שורת קוד

כשהקוד מושהה בשורה שמכילה פונקציה שלא רלוונטית לבעיה שאתם מנסים לנפות באגים, לוחצים על Step over דילוג כדי להריץ את הפונקציה בלי להיכנס אליה.

בחירה באפשרות 'העברה'.

לדוגמה, נניח שאתם מנסים לנפות באגים בקוד הבא:

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
}

החשבון שלך הושהה ב-A. כשמקישים על Step over, DevTools מפעיל את כל הקוד בפונקציה שעוברים עליה, כלומר B ו-C. לאחר מכן, כלי הפיתוח יושהה ב-D.

מעבר לשורת קוד

כשמפסיקים בשורת קוד שמכילה קריאה לפונקציה שקשורה לבעיה שבה מנסים לנפות באגים, לוחצים על Step into כניסה כדי לבדוק את הפונקציה לעומק.

בחירה באפשרות 'כניסה לקוד'.

לדוגמה, נניח שאתם מנסים לנפות באגים בקוד הבא:

function updateHeader() {
  var day = new Date().getDay();
  var name = getName(); // A
  updateName(name);
}
function getName() {
  var name = app.first + ' ' + app.last; // B
  return name;
}

החשבון שלך הושהה ב-A. כשמקישים על Step into, DevTools מבצע את שורת הקוד הזו ואז נעצר ב-B.

יציאה משור של קוד

כשמפעילים השהיה בתוך פונקציה שלא קשורה לבעיה שאתם מנסים לנפות באגים, לוחצים על יציאה יציאה כדי להריץ את שאר הקוד של הפונקציה.

בוחרים באפשרות 'יציאה מהצ'אט'.

לדוגמה, נניח שאתם מנסים לנפות באגים בקוד הבא:

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
}

החשבון שלך הושהה ב-A. כשמקישים על יציאה מהפונקציה, DevTools מבצע את שאר הקוד ב-getName(), שהוא רק B בדוגמה הזו, ואז מושהה ב-C.

הרצת כל הקוד עד לשורה מסוימת

כשמנפים באגים בפונקציה ארוכה, יכול להיות שיש הרבה קוד שלא קשור לבעיה שאתם מנפים.

אפשר לעבור על כל השורות, אבל זה יכול להיות מייגע. אפשר להגדיר נקודת עצירה בשורה של קוד בשורה הרלוונטית, ואז ללחוץ על המשך ביצוע הסקריפט המשך ביצוע הסקריפט, אבל יש דרך מהירה יותר.

לוחצים לחיצה ימנית על שורת הקוד הרצויה ובוחרים באפשרות Continue to here. DevTools מפעיל את כל הקוד עד לנקודה הזו, ואז מושהה בשורה הזו.

בוחרים באפשרות 'המשך ל'כאן'.

המשך ביצוע הסקריפט

כדי להמשיך את ביצוע הסקריפט אחרי השהיה, לוחצים על המשך ביצוע הסקריפט המשך ביצוע הסקריפט. DevTools מריצים את הסקריפט עד לנקודת העצירה הבאה, אם יש כזו.

בוחרים באפשרות 'המשך ביצוע הסקריפט'.

אילוץ ביצוע הסקריפט

כדי להתעלם מכל נקודות העצירה ולאלץ את הסקריפט להמשיך את הביצוע, לוחצים לחיצה ארוכה על המשך ביצוע הסקריפט המשך ביצוע הסקריפט ובוחרים באפשרות אילוץ ביצוע הסקריפט אילוץ ביצוע הסקריפט.

בוחרים באפשרות 'אילוץ ביצוע הסקריפט'.

שינוי ההקשר של שרשור

כשעובדים עם משימות אינטרנט או עם שירותי אינטרנט, לוחצים על הקשר שמופיע בחלונית Threads כדי לעבור אליו. סמל החץ הכחול מייצג את ההקשר שנבחר כרגע.

חלונית השרשורים.

חלונית שרשורים בצילום המסך שלמעלה מסומנת בקו כחול.

לדוגמה, נניח שהפעלתם השהיה בנקודת עצירה גם בסקריפט הראשי וגם בסקריפט של העובד בשירות. אתם רוצים להציג את המאפיינים המקומיים והגלובליים של הקשר של ה-service worker, אבל בחלונית Sources מוצג הקשר הסקריפט הראשי. לחיצה על הרשומה של ה-service worker בחלונית 'שרשראות' תאפשר לכם לעבור להקשר הזה.

הדגמה של ביטויים מופרדים בפסיקים

הדילוג על ביטויים מופרדים בפסיקים מאפשר לנפות באגים בקוד שהוקטן. לדוגמה, הקוד הבא:

function foo() {}

function bar() {
  foo();
  foo();
  return 42;
}

bar();

אחרי שמצמצמים אותו, הוא מכיל ביטוי foo(),foo(),42 שמופרד בפסיקים:

function foo(){}function bar(){return foo(),foo(),42}bar();

כלי ניפוי הבאגים עובר על ביטויים כאלה באותו אופן.

צעדים בביטוי שמופרד בפסיקים.

לכן, התנהגות הצעדים זהה:

  • בין קוד מינימלי לקוד שנכתב.
  • כשמשתמשים במפות מקור כדי לנפות באגים בקוד הממוזער בהתאם לקוד המקורי. במילים אחרות, כשרואים נקודות-פסיק, תמיד אפשר לצפות לעבור עליהן, גם אם המקור בפועל שבו מבצעים את ניפוי הבאגים עבר אופטימיזציה.

הצגה ועריכה של נכסים מקומיים, נכסי סגירה ונכסים גלובליים

כשהקוד מושהה בשורת קוד מסוימת, אפשר להשתמש בחלונית היקף כדי להציג ולערוך את הערכים של המאפיינים והמשתנים בהיקפים המקומי, הסגור והגלובלי.

  • לוחצים לחיצה כפולה על ערך המאפיין כדי לשנות אותו.
  • מאפיינים שלא ניתן למנות אותם מוצגים באפור.

חלונית ההיקף.

חלונית היקף בצילום המסך שלמעלה מסומנת בכחול.

הצגת סטאק הקריאות הנוכחי

כשאתם מושהים בשורת קוד, תוכלו להשתמש בחלונית Call Stack כדי להציג את סטאק הקריאות שהביא אתכם לנקודה הזו.

לוחצים על רשומה כדי לדלג לשורת הקוד שבה התבצעה הקריאה לפונקציה הזו. סמל החץ הכחול מייצג את הפונקציה ש-DevTools מדגישה כרגע.

חלונית Call Stack.

חלונית Call Stack בצילום המסך שלמעלה מסומנת בקו כחול.

הפעלה מחדש של פונקציה (מסגרת) ב-call stack

כדי לבחון את ההתנהגות של פונקציה ולהריץ אותה מחדש בלי שתצטרכו להפעיל מחדש את כל תהליך ניפוי הבאגים, אתם יכולים להפעיל מחדש את הביצוע של פונקציה אחת כשהיא מושהית. במילים אחרות, אפשר להפעיל מחדש את המסגרת של הפונקציה ב-call stack.

כדי להפעיל מחדש מסגרת:

  1. להשהות את ביצוע הפונקציה בנקודת עצירה. בחלונית Call Stack מתועד סדר הקריאות לפונקציות.
  2. בחלונית Call Stack, לוחצים לחיצה ימנית על פונקציה ובוחרים באפשרות Restart frame בתפריט הנפתח.

    בחירת האפשרות 'הפעלת המסגרת מחדש' מהתפריט הנפתח.

כדי להבין איך פועלת Restart frame, אפשר להיעזר בקוד הבא:

function foo(value) {
    console.log(value);
    bar(value);
}

function bar(value) {
    value++;
    console.log(value);
    debugger;
}

foo(0);

הפונקציה foo() מקבלת את 0 כארגומנט, מתעדת אותו ביומן ומפעילה את הפונקציה bar(). הפונקציה bar(), בתורה, מגדילה את הארגומנט.

אפשר לנסות להפעיל מחדש את המסגרות של שתי הפונקציות באופן הבא:

  1. מעתיקים את הקוד שלמעלה לקטע קוד חדש ומריצים אותו. הביצוע נעצר בנקודת העצירה (breakpoint) בשורת הקוד debugger.
  2. שימו לב שבכלי לניפוי הבאגים מוצג הערך הנוכחי לצד הצהרת הפונקציה: value = 1. הערך הנוכחי לצד הצהרת הפונקציה.
  3. מפעילים מחדש את המסגרת bar(). הפעלה מחדש של המסגרת bar().
  4. לוחצים על F9 כדי לעבור דרך ביטוי הוספת הערך. הוספת ערך לערך הנוכחי. שימו לב שהערך הנוכחי עולה: value = 2.
  5. לחלופין, אפשר ללחוץ פעמיים על הערך בחלונית היקף כדי לערוך אותו ולהגדיר את הערך הרצוי. עריכת הערך בחלונית 'היקפים'.
  6. נסו להפעיל מחדש את המסגרת bar() ולעבור על משפט העלייה כמה פעמים נוספות. הערך ממשיך לעלות. הפעלה מחדש של המסגרת bar().

הפעלה מחדש של המסגרת לא מאפסת את הארגומנטים. במילים אחרות, ההפעלה מחדש לא משחזרת את המצב הראשוני בקריאה לפונקציה. במקום זאת, הוא פשוט מעביר את מצביע הביצוע לתחילת הפונקציה.

לכן, ערך הארגומנט הנוכחי נשמר בזיכרון במהלך הפעלות מחדש של אותה פונקציה.

  1. עכשיו מפעילים מחדש את המסגרת foo() בCall Stack. הפעלה מחדש של המסגרת foo(). שימו לב שהערך הוא 0 שוב. ALT_TEXT_HERE

ב-JavaScript, שינויים בארגומנטים לא גלויים (משתקפים) מחוץ לפונקציה. פונקציות בתצוגת עץ מקבלות ערכים, ולא את המיקומים שלהם בזיכרון. 1. ממשיכים את ביצוע הסקריפט (F8) כדי להשלים את המדריך הזה.

הצגת מסגרות שכלולות ברשימת קטעי הקוד להתעלמות

כברירת מחדל, בחלונית Call Stack מוצגים רק המסגרות שרלוונטיות לקוד, והיא לא מציגה סקריפטים שנוספו אל הגדרות. Settings (הגדרות) > Ignore List (רשימת ההשמטות).

סטאק קריאות.

כדי להציג את סטאק הקריאות המלא, כולל מסגרות של צד שלישי, מפעילים את האפשרות הצגת מסגרות שכלולות ברשימת קטעי הקוד להתעלמות בקטע סטאק קריאות.

הצגת מסגרות שכלולות ברשימת קטעי הקוד להתעלמות.

אפשר לנסות את זה בדף ההדגמה הזה:

  1. בחלונית מקורות, פותחים את הקובץ src > app > app.component.ts.
  2. מגדירים נקודת עצירה בפונקציה increment().
  3. בקטע Call Stack, מסמנים את התיבה Show ignore-listed frames או מבטלים את הסימון שלה, ומעיינים ברשימת המסגרות הרלוונטית או המלאה ב-Call Stack.

הצגת מסגרות אסינכרוניות

אם המסגרת שבה אתם משתמשים תומכת בכך, הכלי DevTools יכול לעקוב אחרי פעולות אסינכררוניות על ידי קישור של שני החלקים של הקוד האסינכרוני.

במקרה כזה, במקבץ הקריאות מוצגת כל היסטוריית הקריאות, כולל מסגרות קריאה אסינכרוניות.

מסגרות קריאה אסינכרוניות.

העתקת דוח הקריסות

לוחצים לחיצה ימנית בכל מקום בחלונית Call Stack ובוחרים באפשרות Copy stack trace כדי להעתיק את סטאק הקריאות הנוכחי ללוח.

בוחרים באפשרות 'העתקת דוח הקריסות'.

דוגמה לפלט:

getNumber1 (get-started.js:35)
inputsAreEmpty (get-started.js:22)
onClick (get-started.js:15)

ניווט בעץ הקבצים

משתמשים בחלונית דף כדי לנווט בעץ הקבצים.

קיבוץ קבצים שנוצרו וקבצים שנפרסו בעץ הקבצים

כשמפתחים אפליקציות אינטרנט באמצעות מסגרות (לדוגמה, React או Angular), יכול להיות שיהיה קשה לנווט בין המקורות בגלל הקבצים המקוצרים שנוצרים על ידי כלי ה-build (לדוגמה, webpack או Vite).

כדי לעזור לכם לנווט בין המקורות, בחלונית מקורות > דף אפשר לקבץ את הקבצים בשתי קטגוריות:

  • סמל הקוד. Authored. דומים לקובצי המקור שמוצגים בסביבת הפיתוח המשולבת (IDE). כלי הפיתוח יוצרים את הקבצים האלה על סמך מפות המקור שסופקו על ידי כלי ה-build.
  • סמל הפריסה. Deployed. הקבצים בפועל שהדפדפן קורא. בדרך כלל הקבצים האלה מוקטנים.

כדי להפעיל את הקיבוץ, מפעילים את האפשרות תפריט שלוש הנקודות. > קיבוץ קבצים לפי מחבר/פריסה ניסיונית. בתפריט של שלוש הנקודות בחלק העליון של עץ הקבצים.

קיבוץ קבצים לפי 'כפי שנוצר'/'פרוס'.

הסתרת מקורות שכלולים ברשימת הפריטים להתעלמות מעץ הקבצים

כדי לעזור לכם להתמקד רק בקוד שאתם יוצרים, כברירת מחדל, כל הסקריפטים או הספריות שנוספו ל-הגדרות. הגדרות > רשימת ההתעלמות מופיעים באפור בחלונית מקורות > דף.

כדי להסתיר סקריפטים כאלה לגמרי, בוחרים באפשרות מקורות > דף > תפריט שלוש הנקודות. > הסתרת מקורות ברשימת ההתעלמות ניסיונית..

לפני ואחרי הסתרת מקורות שכלולים ברשימת הפריטים להתעלמות.

התעלמות מסקריפט או מדפוס של סקריפטים

אפשר להתעלם מסקריפט כדי לדלג עליו במהלך ניפוי הבאגים. כשסקריפט מתעלם, הוא מוסתר בחלונית Call Stack, ואף פעם לא נכנסים לפונקציות של הסקריפט כשעוברים על הקוד.

לדוגמה, נניח שאתם בודקים את הקוד הזה:

function animate() {
  prepare();
  lib.doFancyStuff(); // A
  render();
}

A היא ספרייה של צד שלישי שאתם סומכים עליה. אם אתם בטוחים שהבעיה שאתם מנסים לנפות באגים שלה לא קשורה לספרייה של הצד השלישי, כדאי להתעלם מהסקריפט.

איך מתעלמים מסקריפט או מספרייה בעץ הקבצים

כדי להתעלם מתסריט ספציפי או מספרייה שלמה:

  1. בקטע מקורות > דף, לוחצים לחיצה ימנית על ספרייה או על קובץ סקריפט.
  2. בוחרים באפשרות הוספת ספרייה/סקריפט לרשימת קטעי הקוד להתעלמות.

אפשרויות להתעלמות מתיקיית או מקובץ סקריפט.

אם לא הסתרתם מקורות ברשימת ההתעלמות, תוכלו לבחור מקור כזה בעץ הקבצים, ובבאנר האזהרה אזהרה. ללחוץ על הסרה מרשימת ההתעלמות או על הגדרה.

בקובץ שנבחר שמוגדרת בו התעלמות מוצגים הלחצנים 'הסרה' ו'הגדרה'.

לחלופין, אפשר להסיר מהרשימה ספריות וסקריפטים מוסתרים ומתעלמים בקטע הגדרות. הגדרות > רשימת התעלמות.

התעלמות מסקריפט מחלונית העריכה

כדי להתעלם מסקריפט בחלונית Editor:

  1. פתח את הקובץ.
  2. לוחצים לחיצה ימנית במקום כלשהו.
  3. בוחרים באפשרות הוספת סקריפט לרשימת קטעי הקוד להתעלמות.

התעלמות מסקריפט בחלונית העריכה.

אפשר להסיר סקריפט מרשימת קטעי הקוד להתעלמות דרך הגדרות. הגדרות > רשימת קטעי הקוד להתעלמות.

התעלמות מסקריפט בחלונית Call Stack

כדי להתעלם מסקריפט בחלונית Call Stack:

  1. לוחצים לחיצה ימנית על פונקציה מהסקריפט.
  2. בוחרים באפשרות הוספת סקריפט לרשימת קטעי הקוד להתעלמות.

התעלמות מסקריפט בחלונית Call Stack.

אפשר להסיר סקריפט מרשימת קטעי הקוד להתעלמות דרך הגדרות. הגדרות > רשימת קטעי הקוד להתעלמות.

התעלמות מסקריפט מההגדרות

הגדרות. הגדרות > רשימת התעלמות.

הרצת קטעי קוד לניפוי באגים מכל דף

אם אתם מוצאים את עצמכם מריצים שוב ושוב את אותו קוד ניפוי באגים במסוף, כדאי לכם להשתמש בקטעי קוד. קטעי קוד הם סקריפטים שניתן להריץ, שאתם יוצרים, מאחסנים ומפעילים ב-DevTools.

מידע נוסף זמין במאמר הרצת קטעי קוד מכל דף.

מעקב אחר הערכים של ביטויים מותאמים אישית של JavaScript

בעזרת חלונית המעקב אפשר לעקוב אחרי הערכים של ביטויים מותאמים אישית. אפשר לצפות בכל ביטוי חוקי של JavaScript.

חלונית הצפייה.

  • לוחצים על Add Expression (הוספת ביטוי) הוספת ביטוי כדי ליצור ביטוי חדש לצפייה.
  • לוחצים על רענון רענון כדי לרענן את הערכים של כל הביטויים הקיימים. הערכים מתעדכנים באופן אוטומטי במהלך הבדיקה של הקוד.
  • מעבירים את העכבר מעל ביטוי ולוחצים על Delete Expression (מחיקה של הביטוי) מחיקת ביטוי כדי למחוק אותו.

בדיקה ועריכה של סקריפטים

כשפותחים סקריפט בחלונית Page, תוכן הסקריפט מוצג בחלונית Editor בכלי הפיתוח. בחלונית Editor אפשר לעיין בקוד ולערוך אותו.

בנוסף, אפשר לשנות את התוכן באופן מקומי או ליצור סביבת פיתוח ולשמור את השינויים שתבצעו ב-DevTools ישירות במקורות המקומיים.

איך הופכים קובץ מינימלי לקריא

כברירת מחדל, בחלונית מקורות מתבצעת הדפסה יפה של קובצי minify. כשהקוד מודפס בצורה מסודרת, יכול להיות שב-Editor יוצגו כמה שורות של קוד ארוך אחד, עם - כדי לציין שזו המשך השורה.

שורה ארוכה של קוד בפורמט יפהפייה שמוצגת בכמה שורות, עם הסימן '-' כדי לציין המשך שורה.

כדי לראות את הקובץ הממוזער כפי שהוא נטען, לוחצים על { } בפינה הימנית התחתונה של העורך.

כיווץ של בלוקים של קוד

כדי לכווץ בלוק קוד, מעבירים את העכבר מעל מספר השורה בעמודה הימנית ולוחצים על מכווצים. Collapse.

כדי לפתוח את בלוק הקוד, לוחצים על {...} שלצידו.

כדי להגדיר את ההתנהגות הזו, אפשר לעיין במאמר הגדרות. הגדרות > העדפות > מקורות.

עריכת סקריפט

כשמתקנים באג, בדרך כלל רוצים לבדוק כמה שינויים בקוד ה-JavaScript. אין צורך לבצע את השינויים בדפדפן חיצוני ואז לטעון מחדש את הדף. אפשר לערוך את הסקריפט ב-DevTools.

כדי לערוך סקריפט:

  1. פותחים את הקובץ בחלונית Editor (עריכה) בחלונית Sources (מקורות).
  2. מבצעים את השינויים בחלונית עריכה.
  3. כדי לשמור, מקישים על Command+S (ב-Mac) או על Ctrl+S (ב-Windows וב-Linux). כלי הפיתוח מצרפים את קובץ ה-JS כולו למנוע ה-JavaScript של Chrome.

    חלונית העריכה.

    חלונית Editor בצילום המסך שלמעלה מסומנת בקו כחול.

עריכת פונקציה מושהית בשידור חי

בזמן שההפעלה מושהית, אפשר לערוך את הפונקציה הנוכחית ולהחיל שינויים באופן פעיל, בכפוף למגבלות הבאות:

  • אפשר לערוך רק את הפונקציה העליונה במקבץ הקריאות.
  • אסור שיהיו קריאות רפרסיביות לאותה פונקציה בהמשך הסטאק.

כדי לערוך פונקציה בזמן אמת:

  1. להשהות את הביצוע באמצעות נקודת עצירה.
  2. עורכים את הפונקציה המושהית.
  3. מקישים על Command או על Control + S כדי להחיל את השינויים. מנתח הבאגים מפעיל מחדש את הפונקציה באופן אוטומטי.
  4. ממשיכים את הביצוע.

בסרטון הבא מוסבר תהליך העבודה הזה.

בדוגמה הזו, למשתנים addend1 ו-addend2 יש בהתחלה סוג string שגוי. לכן, במקום להוסיף מספרים, מחרוזות מחוברות. כדי לפתור את הבעיה, צריך להוסיף את הפונקציות parseInt() במהלך העריכה בשידור חי.

כדי לחפש טקסט בסקריפט:

  1. פותחים את הקובץ בחלונית Editor (עריכה) בחלונית Sources (מקורות).
  2. כדי לפתוח את סרגל החיפוש המובנה, מקישים על Command+F (ב-Mac) או על Ctrl+F (ב-Windows וב-Linux).
  3. מזינים את השאילתה בסרגל. חיפוש. אפשר גם:
    • לוחצים על התאמה לאותיות רישיות. Match Case כדי להפוך את השאילתה לתלויה באותיות רישיות.
    • לוחצים על לחצן ביטוי רגולרי (regex). שימוש בביטוי רגולרי כדי לחפש באמצעות ביטוי RegEx.
  4. מקישים על Enter. כדי לעבור לתוצאת החיפוש הקודמת או הבאה, מקישים על הלחצן למעלה או למטה.

כדי להחליף את הטקסט שמצאתם:

  1. בסרגל החיפוש, לוחצים על הלחצן מחליפים. החלפה. מחליפים.
  2. מקלידים את הטקסט שרוצים להחליף בו את הטקסט הקיים, ולוחצים על החלפה או על החלפה של הכול.

השבתת JavaScript

השבתת JavaScript באמצעות כלי הפיתוח ל-Chrome