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

Browser detection

רן בר-זיק מאי 5, 2013 7:48 am אין תגובות

איך מגלים את הדפדפן ולמה אסור לעשות את זה באפליקציה/אתר אינטרנט מודרני?

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

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

אתר המותאם לאינטרנט אקספלורר בלבד
אתר המותאם לאינטרנט אקספלורר בלבד

מדוע זה קורה? התשובה היא שבעבר הרחוק (מאד) היה נהוג לבנות אתרים התומכים בדפדפנים מסוימים בלבד – בדרך כלל אקספלורר, אבל גם למשל גרסאות מסוימות של נטסקייפ. על מנת לבצע את ההתאמות, המפתחים אז היו נוהגים לבצע Browser detection – כלומר גילוי של הדפדפן והגרסה שלו באמצעות ה-user agent. במידה וגרסת הדפדפן לא תאמה למה שהמפתחים תמכו בו, הם העיפו הודעת שגיאה ב-alert.

איך מוצאים את ה-user agent? משתמשים בפקודה הבאה:


window.navigator.userAgent

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


if (/MSIE (\d+\.\d+);/.test(navigator.userAgent)){ //test for MSIE x.x;
 var ieversion=new Number(RegExp.$1) // capture x.x portion and store as a number
 if (ieversion>=9)
  document.write("You're using IE9 or above")
 else if (ieversion>=8)
  document.write("You're using IE8 or above")
 else if (ieversion>=7)
  document.write("You're using IE7.x")
 else if (ieversion>=6)
  document.write("You're using IE6.x")
 else if (ieversion>=5)
  document.write("You're using IE5.x")
}
else
 document.write("n/a")

אז מדוע כשאני מדבר על Browser detection אני מדבר על העבר הרחוק? מהסיבה הפשוטה שהיום, בפיתוח ווב מודרני, אנו לא עושים Browser Detection. אלא אם כן אנו עובדים במקומות שהזמן קפא שם מלכת, כמו באתר רשות המיסים של ממשלת ישראל, למשל, שם חיים בעולם שבו אינטרנט אקספלורר 6 הוא הדפדפן הפופולרי ושאר הדפדפנים הם בגדר מדע בדיוני. נשאלת השאלה, למה? למה לא להשתמש ב-Browser detection על מנת להבין, למשל, אם הדפדפן תומך בתגית וידאו של HTML5, או בפיצ'רים אחרים? הרי אם למשל יש לי אפליקציה משוכללת התומכת ב-Video, הדבר הכי אינטואטיבי הוא לבדוק אם הדפדפן שלי הוא פיירפוקס, כרום או אינטרנט אקספלורר 9 ומעלה ובמידה ולא להדפיס בפני המשתמש שגיאה שמזמינה אותו לעדכן את הדפדפן שברשותו.

התשובה מתחלקת לשניים. ראשית, הקוד של Browser detection, כפי שאפשר לראות מהדוגמה לעיל, מסובך ומורכב לתחזוקה – במיוחד אם אנחנו צריכים לבדוק גרסאות של כרום, פיירפוקס, אופרה וספארי בנוסף לכל (שלא לדבר על כל הדפדפנים הסלולריים!). שנית, ויותר חשוב, אנו לא יודעים איזה מהפך יהיה בשוק הדפדפנים עוד חודש או עוד חודשיים. כך למשל, שכרום יצא לאוויר העולם, המון המון אתרים לא תמכו בו. אותה הבעיה התרחשה עם צאתו לאוויר העולם של אינטרנט אקספלורר 8 ואקספלורר 9. מי יודע איזה דפדפן חדש יצא מחר? או האם מפתחי דפדפן מרכזי יחליטו לשנות את המנוע מאחוריו ולקרוא לו בשם חדש?

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

אז מה התחליף ל-Browser detection? על זה אכתוב במאמר הבא: Feature detection.

כדאי תמיד להשאר מעודכנים! אם יש לכם טלגרם, בדקו את ערוץ הטלגרם של האתר שבו אני מעדכן על פוסטים חדשים 🙂 אם אתם רוצים ללמוד תכנות באופן מקיף ומסודר, הצטרפו לאלפי הלומדים בפרויקט "ללמוד ג'אווהסקריפט בעברית" שמלמד לתכנת בג'אווהסקריפט, ב-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 | הצהרת הנגישות של האתר | אבטחת מידע ודיווח על בעיית אבטחת מידע

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