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

ES2020 – globalThis

רן בר-זיק אוקטובר 27, 2019 7:07 am 3 תגובות

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

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

תקן ES2020 מכיל כמה תוספות חשובות לג'אווהסקריפט. אחת התוספות המעניינות (אך הקלות להבנה) היא globalThis. לעתים, במיוחד בסקריפטי בדיקות (אך לא רק!) יש לנו צורך לגשת לגלובל. מה זה גלובל? זה בעצם הסקופ (Scope) העליון ביותר. אם אנחנו כותבים ג'אווהסקריפט בסביבת דפדפן, זה ברוב המקרים ה-window שלנו או ה-self. אם אנו כותבים בסביבת Node.js, זה יכול להיות ה-this או global. תלוי.

העניינים היו מסתבכים אם הייתם כותבים תוספים (כמו לכרום). הרבה ניסו להשיג גישה ל-this גלובלי באופן הזה:

(new Function("return this")())

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

function foo() {
	// If we're in a browser, the global namespace is named 'window'. If we're
	// in node, it's named 'global'. If we're in a shell, 'this' might work.
	(typeof window !== "undefined"
		? window
		: (typeof process === 'object' &&
		   typeof require === 'function' &&
		   typeof global === 'object')
			? global
			: this);
}

וזה קוד שמשתמשים בו, כן?

באופן עקרוני, להשתמש בסקופ הגלובלי בדרך כלל זה רעיון רע. אנו צריכים להזהר שלא לזהם את הסקופ הזה בגלל כמה סיבות – הסיבה הראשית היא התנגשויות. אם אנו קובעים משתנה בסקופ הגלובלי כל אחד יכול לדרוס אותו בקלות ואפילו לא לדעת שהוא עשה בלגן. אבל כן יוצא לנו הרבה פעמים לעבוד עם סקופ גלובלי – או בשימוש במתודות טבעיות של הסביבה שבה ג'אווהסקריפט רצה (למשל setinterval, או window.location). הרבה מתכנתים עושים שימוש בלתי מודע ב-this. למשל כותבים setInterval במקום window.setInterval (בסביבת דפדפן) או global.setInterval (ב-Node.js) וזה עובד, עד הרגע שזה לא עובד. כי הם מריצים את הקוד הזה בסביבות אחרות. מה זאת אומרת סביבות אחרות? למשל בדיקות אוטומטיות שהסביבה שלהן יכולה להשתנות (למשל בדיקות אוטומטיות לאפליקציה צד לקוח שרצה בסביבת דפדפן אבל כזו שאנו מריצים אותה מהטרמינל). או קוד שהוא מודול ב-Node.js ואנו רוצים שיעבוד בסביבת דפדפן.

במקרים האלו, שבהם אנו נעזרים במתודות או משתנים שמגיעים מהסביבה הגלובלית, מומלץ להשתמש ב-globalThis שפשוט מחזיר את האובייקט הגלובלי. בין אם מדובר ב-window, ב-self או ב-global. השימוש שלו הוא הכי פשוט בעולם. איפה שאנחנו שמים window (בדפדפן) אנו מציבים globalThis. למשל:

globalThis.myVariable = 'Hi, this is your friendly global variable';
globalThis.document.querySelector('body').innerText = globalThis.myVariable;

אין פה יותר מדי משחקים. הנה הדוגמה החיה:

See the Pen globalThis simple example by Ran Bar-Zik (@barzik-the-vuer) on CodePen.

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

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

3 תגובות

  1. משתמש אנונימי (לא מזוהה) הגב אוקטובר 27, 2019 בשעה 8:55 pm

    חזק!

  2. יובל פרוס הגב אוקטובר 29, 2019 בשעה 3:54 pm

    שימושי ביותר!

  3. שרק הגב דצמבר 22, 2020 בשעה 5:13 pm

    מאמר פצצה

השארת תגובה

ביטול

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

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

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