אינטרנט ישראל
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
  • ראשי
  • אודות רן בר-זיק ואינטרנט ישראל
  • ערוץ טלגרם
  • מסטודון
  • התחברו אלי בטוויטר
  • התחברו אלי בלינקדאין
  • ספר ג'אווהסקריפט
ראשי » פיתוח אינטרנט » jQuery למתקדמים » ביצוע בדיקת ביצועים ל-JavaScript עם JSLitmus

ביצוע בדיקת ביצועים ל-JavaScript עם JSLitmus

רן בר-זיק ספטמבר 30, 2012 8:07 am אין תגובות

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

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.

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

אבל יש בעיה עם כל השיטות האלו: הן מודדות כמה זמן הסקריפט רץ – בפעם אחת. אם אני רוצה לבדוק יעילות, אני רוצה לבדוק כמה פעמים בשניה אני יכול להריץ את הסקריפט שלי וכמובן להריץ אותו כמה וכמה פעמים בדפדפנים שונים. למרות שאני יכול באופן תיאורטי לעשות את זה עם הפרופיילר או עם הקונסולה, זה ידרוש ממני המון זמן ומאמצים. ישנם שני פתרונות יותר אלגנטיים. הראשון הוא JSpref המוכר יותר והוובי, שדורש ממני להעתיק ולהדביק את הקוד ואז לבצע את הבדיקה. הוא מעולה כאשר יש לי קוד קצר ומבנה HTML פשוט. אבל אם אני רוצה לבדוק את הסקריפט שלי בסביבתו "הטבעית", אני צריך לחשוב על פתרון לא וובי. הפתרון הזה הוא ספריה קטנה ואלגנטית בשם JSLitmus שבודקת (ומציגה) את מספר הפעמים שקוד מסוים רץ בשניה.

דוגמאות? תמיד טוב. נניח שיש לי קוד jQuery פשוט לחלוטין שבו יש שלושה סלקטורים: אחד שבוחר אלמנט על פי ID, השני שבוחר את אותו אלמנט על פי Class והשלישי שבוחר את אותו אלמנט על פי תכונה שלו.

זה האלמנט, פסקה פשוטה שיש לה ID, Class ותכונת REL:


<p id="test1" class="test1" rel="test1">This is test paragraph</p>

וזה קוד הג'אווהסקריפט שלי:


$('#test_element');
$('.test_element');
$('p[rel="test1"]');

איך אני אמדוד את היעילות של כל סלקטור? JSLitmus מאפשרת לי לעשות את זה בפשטות מדהימה. ראשית אני צריך לגשת אל JSLitmus ולהוריד את קוד המקור שלה (יש שם גם דמו מעולה). אחרי כן, אני צריך לכלול אותו בדף שלי. אחרי שעשיתי את זה, אני צריך להכניס לתוך הדף את הקוד ה-HTMLי הזה:


<div id="test_element" style="overflow:hidden; width: 1px; height:1px;"></div>

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


JSLitmus.test('Select ID', function() {
	$('#test_element');
});

מה פה קורה פה? קראתי למתודה JSLitmus.test שצריכה שני ארגומנטים. הראשון הוא שם המבחן שלי שיכול להיות כל טקסט שהוא והשני הוא פונקציה אנונימית שעוטפת את קטע הקוד שכלול במבחן. ובדוגמה שלנו:


JSLitmus.test('Select ID', function() {
	$('#test_element');
});

JSLitmus.test('Select By Class', function() {
	$('.test_element');
});

JSLitmus.test('Select By Attribute', function() {
	$('p[rel="test1"]');
});

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

בדיקת JavaScript
בדיקת JavaScript

מיד מתחילה ההרצה של הפעולות השונות ואחרי מספר שניות (תלוי במה שרציתי לבדוק, אני אראה את התוצאות! רוצים לדעת מה הסלקטור הכי מהיר? כמה פעמים הדפדפן שלכם מריץ את הבדיקות? למה שלא תיכנסו לדף הדמו שהכנתי על מנת לבדוק את הכל באופן חי?

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

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-Node.js ובריאקט וגם מלמד על תרומה לקוד פתוח. גם ספרים דיגיטליים וגם ספרים מודפסים. בשיתוף הקריה האקדמית אונו ובתמיכת חברות מובילות כגון Wix, Outbrain, Elementor, Iron Source, Chegg, Really Good ועוד.
ג'אווה סקריפט ו-jQuery באתרי אינטרנט

השארת תגובה

ביטול

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

ללמוד לתכנת ג'אווהסקריפט בעברית שגייס יותר משלוש מאות אלף שקל ולמעלה מ-2000 תומכים - בואו ללמוד עכשיו איך לתכנת.

רשימת הנושאים
  • מדריכים
    • ריאקט
    • טייפסקריפט
    • ECMAScript 6
    • ES20XX
    • Node.js
    • Express
    • רספברי פיי
    • Babel
    • docker
    • MongoDB
    • Git
    • לימוד MySQL
    • SASS
    • jQuery
    • CSS3
    • HTML 5
    • SVN
    • LESS
  • פיתוח אינטרנט
    • פתרונות ומאמרים על פיתוח אינטרנט
    • jQuery Scripts
    • jQuery למתקדמים
    • יסודות בתכנות
    • נגישות אינטרנט
  • חדשות אינטרנט
  • מידע כללי על אינטרנט
    • רשת האינטרנט
    • בניית אתרי אינטרנט
  • rss logo

    לכל המאמרים

    לכל המאמרים שפורסמו באינטרנט ישראל משנת 2008 ועד עכשיו.
  • rss logo

    RSS Feed

    משתמשים בקורא RSS? אם כן, עקבו אחרי אינטרנט ישראל באמצעות פיד ה-RSS!
    מה זה RSS?
  • Twitter logo

    עקבו אחרי בטוויטר

    בחשבון הטוויטר שלי אני מפרסם עדכונים מהירים על חדשות בתחום התכנות והיזמות, התרעות על מצבי חירום ורכילות בוערת על תחום הווב.
    מה זה טוויטר?
  • facebook like image

    ערוץ הטלגרם של אינטרנט ישראל

    בערוץ הטלגרם של אינטרנט ישראל אני מפרסם את הפוסטים של באתר וכן עדכונים טכנולוגיים נוספים.
    מה זה טלגרם?
  • github logo

    הפרויקטים שלי בגיטהאב

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

כל הזכויות שמורות לרן בר-זיק ולאינטרנט ישראל | מדיניות הפרטיות של אתר אינטרנט ישראל | אתר אינטרנט ישראל נגיש לפי תקן WCAG 2.0 AA | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

גלילה לראש העמוד