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

ES2020 optional chaining

רן בר-זיק דצמבר 8, 2019 7:07 am 2 תגובות

לא עוד הודעות שגיאה בגלל שחסרה תכונה באובייקט שאליו אתם מנסים לגשת.

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

אחד מהפיצ'רים החשובים והנדרשים ביותר הגיע אל ג'אווהסקריפט בתקן החדש של ES2020. שם הפיצ'ר הוא "שרשור אפשרי" או בשפת גויי הים Optional Chaining. הוא פיצ'ר אולטרא חשוב ושימושי.

הפיצ'ר הזה פותר את בעית שגיאת הסקריפט כאשר אני מנסה לגשת אל תכונה או מתודה שנמצאת עמוק בהיררכית האובייקט. למשל משהו כזה:

const myData = obj.prop1.prop2.prop3

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

const myObject = {};

const myVar = myObject.prop1.prop2;

console.log('myVar', myVar); // Uncaught TypeError: Cannot read property 'prop2' of undefined

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

const myObject = {};

let myVar;

if (myObject.prop1) {
  myVar = myObject.prop1.prop2;
}

console.log('myVar', myVar); // myVar undefined

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

בדיוק כדי להמנע מהזוועה הזו ה-TC39 העניקו לנו ב-ES2020 את השרשור האופציונלי. איך זה עובד? פשוט מאוד – על ידי סימן שאלה – במידה ויש את התכונה/מתודה שאנו צריכים – נקבל אותה. במידה ולא, נקבל undefined. איך זה נראה? ככה:

const myObject = {};

const myVar = myObject.prop1?.prop2;

console.log('myVar', myVar); // myVar undefined

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

const myObject = {};

const myVar = myObject.prop1?.prop2?.prop3?.prop4.?();

console.log('myVar', myVar); // myVar undefined

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

בינתיים, הנה Codepen שבו אפשר ללמוד ולבדוק את העניין:

See the Pen Optional chain by Ran Bar-Zik (@barzik-the-vuer) on CodePen.

תודה לשלומי בורוביץ׳ על התיקון 🙂

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

2 תגובות

  1. יוסף הגב דצמבר 8, 2019 בשעה 11:32 am

    אני משתמש בסינטק הזה:
    const myVar = myObject.prop1 ? myObject.prop1.prop2 : undefined;
    קצת יותר אלגנטי מלהשתמש ב- "IF"
    אך ה- פיצר החדש בהחלט יכול להיות יותר נחמד

  2. יוסף הגב דצמבר 8, 2019 בשעה 11:49 am

    בשרשור אובייקט אפשר להשתמש בתנאי המשורשר הזה
    let myVar = myObject.prop1 && myObject.prop1.prop2 && myObject.prop1.prop2.prop3 ? myObject.prop1.prop2.prop3.prop4 : undefined
    זה לא גורם לשגיאה משום שכשהתנאי הראשון מחזיר תשובה שלילית התנאים הבאים לא נבדקים בכלל

השארת תגובה

ביטול

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

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

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