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

זיהוי מצב אופליין באתר

רן בר-זיק דצמבר 3, 2017 7:07 am אין תגובות

בשביל עבודה באופליין לא חייבים להטמיע service worker, אפשר להשתמש ב-API פשוט

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

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

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

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

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

בואו ונדגים. הנה HTML שיש בו שני div. אחד שאני רוצה שיוצג כשאני מחובר והשני שאני רוצה שיוצג כשאני מנותק:


<div id="online" >
  I am online
</div>
<div id="offline" style="display: none;">
    I am offline
</div>

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


window.addEventListener('online',  updateOnlineStatus);
window.addEventListener('offline',  updateOfflineStatus);


function updateOnlineStatus(ev) {
  document.getElementById('online').style.display = 'block'; 
  document.getElementById('offline').style.display = 'none';
}

function updateOfflineStatus(ev) {
  document.getElementById('offline').style.display = 'block'; 
  document.getElementById('online').style.display = 'none';
}

והנה הדוגמה החיה. אתם מוזמנים לבדוק בעצמכם!

See the Pen offline\online event simple demo by Ran Bar-Zik (@barzik) on CodePen.

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

בכרום – פשוט לפתוח את כלי המפתחים -> network ולחפש את הצ׳קבוקס של ׳offline׳:

כלי המפתחים של כרום - מעבר למצב אופליין
כלי המפתחים של כרום – מעבר למצב אופליין

בפיירפוקס – לוחצים על file ובוחרים (זה ממש למטה) במצב של work offline

פיירפוקס - לחיצה על קובץ - ועבודה במצב אופליין
פיירפוקס – לחיצה על קובץ – ועבודה במצב אופליין

פשוט, לא?

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


navigator.onLine

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

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

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

השארת תגובה

ביטול

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

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

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