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

חייו ומותו של באג באינטרנט אקספלורר

רן בר-זיק אפריל 10, 2016 7:07 am תגובה אחת

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

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

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

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

http://internet-israel.com/wp-content/uploads/2016/04/ie11_input_autofocus_issue.mp4

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

יש לכם מושג מה הבעיה יכולה להיות? מה אתם הייתם עושים?

מה שטוב בבאגים של דפדפן האימים זה שיש סבירות גבוהה מאוד שמישהו נתקל בבאג עוד לפניך וטרח לשים שאלה ב-stack overflow, שזה למי שלא יודע, תנ"ך השאלות של כל המפתחים. למרות החיפוש הנמרץ שלנו, לא הצלחנו למצוא שום אזכור לבעיה הזו. הבנו שאנחנו צריכים להתמקד יותר. ניסינו להבין יותר לעומק את הבאג. הדרך הטובה ביותר להתמודד עם באגים של אקספלורר זה לראות מה מפריע לדפדפן הרוע. מסירים את כל האלמנטים, התגיות והקוד הרלוונטי לבעיה – במקרה שלנו ל-input ובודקים אם הבעיה משתחזרת. היא משתחזרת? עוברים לאבא וכך הלאה. לא משתחזרת? בודקים בדרך האלימינציה איזה תג, פקודה או כלל CSS עושה את הבעיה.

גילינו שה-cursor נותר במקום אך ורק אם יש ל-input את תכונת autofocus. התכונה הזו מבצעת פוקוס אוטומטי ל-input והיא מאוד חשובה אם אנו רוצים לאפשר למשתמשים להקליד מיד איך שהמודל נפתח ללא צורך בהזזה והקלקה. גם מבחינת נגישות יש חשיבות ל-autofocus. אחרי שהבנו שהבאג קורה רק אם מוסיפים את autofocus ל-input. יכולנו לנסח את השאילתה לגוגל באופן יותר מוצלח – cursor position IE focus ולהגיע לשאלה הזו ב-stackoverflow ואל הפתרון המיוחל.

מה הפתרון? להסיר את ה-autofocus מה-input להוסיף את הפוקוס בג'אווהסקריפט רק לאחר שה-transition מושלם. במקרה שלנו, ה-transition הוא באורך של 300 מילישניות אז הפוקוס נכנס לפעולה אחרי 350 שניות. כל מה שנותר לנו לעשות זה לארוז את הקוד יפה כאנגולר דירקטיב:

angular.module('my.directive')
  .directive('custom-auto-focus', function ($timeout) {
    return {
      link: function (scope, elm) {
        $timeout(function() {
          elm[0].focus();
        }, 350);
      }
    };
  }); 

מה המסקנה? זה לא פתרון מושלם. כמו כל האק הוא סובל מכמה בעיות – אם נשנה את אורך ה-transition, הפתרון יתפוצץ. הוא מעמיס עוד overhead של משהו שלא אמור להיות שם. autofocus אמור לעשות את הפוקוס האוטומטי ולא קוד JavaScript. זה בדיוק מה שרע בהאקים. מצד שני, אין ממש ברירה.

את הפתרון הצבתי גם בשאלה ב-stack overflow. מי יודע? אולי מישהו יוכל להיעזר בזה בעתיד.

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

תגובה אחת

  1. נעמי הגב אוגוסט 1, 2019 בשעה 12:49 am

    חחחחחחחחחחחחחחחחחחחחחחחחח כמה צחקתי מהמילים שהצמדת למילה דפדפן

השארת תגובה

ביטול

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

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

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