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

ES2020 – מספרים גדולים בג'אווהסקריפט

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

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

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

אחד הבשורות הגדולות שתקן ES2020 מביא עמו הוא BigInt אמיתי בג'אווהסקריפט שמאפשר, סוף סוף, עבודה תקינה עם מספרים גדולים.

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

let myNumber = 9007199254740992;
myNumber++;
console.log('myNumber', myNumber); //9007199254740992

גישה לקבוע המספרי הזה היינו מקבלים עם Number.MAX_SAFE_INTEGER. למשל:

const max = Number.MAX_SAFE_INTEGER;
console.log(max); //9007199254740991

אחד פחות מ-9007199254740992 – כי עם 9007199254740991 עדיין אפשר לעשות את כל הפעולות הנומריות כולל להעלות.

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

let myNumber = BigInt(9007199254740992);
myNumber++;
console.log('myNumber', myNumber.toString()); //9007199254740993

או לחלופין, הצמדת האות "n" למספר הופכת אותו אוטומטית ל-BigInt.

let myNumber = 9007199254740992n;
myNumber++;
console.log('myNumber', myNumber.toString()); //9007199254740993
console.log(typeof myNumber); //bigint

חשוב להדגיש שמדובר בסוג מידע פרימיטיבי שונה לחלוטין, אם תנסו להשוות 42 ל-42n, יצא לכם false (ושוב תודה למגיבים שתקנו אותי). בדיוק כפי שיקרה אם תנסו להשוות מחרוזת טקסט למספר. רוצים לבצע השוואה? חייבים להמיר את הסוג. או את המספר ל-BigInt, או את ה-BigInt למספר:

console.log(42 == 42n); //true
console.log(42 === 42n); //false
console.log(42 === Number(42n)); //true
console.log(BigInt(42) === 42n); //true

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

const rounded = 5n / 2n;
console.log('rounded', rounded.toString()); //2

בת'כלס – שימושי מאוד כאשר מבצעים חישובי זמן מסובכים שמצריכים שימוש במספרים גדולים או כל חישוב אחר. אם אתם פתאום רואים n מסתורי בקוד כלשהו – עכשיו תדעו מהיכן זה מגיע. הקוד הזה זמין בפיירפוקס ובכרום. משתמשים באדג'? ובכן… אתם עדיין בימי הביניים 🙂

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

4 תגובות

  1. יוסף הגב דצמבר 1, 2019 בשעה 10:05 am

    ההשוואה הזו לא מחזירה שגיאה: 42 === 42n
    אלא מחזירה false.
    אם יש שברים הם מעוגלים כלפי מטה ולא כלפי מעלה

    • רן בר-זיק הגב דצמבר 7, 2019 בשעה 11:17 am

      לא שגיאה, למה שתחזיר שגיאה?

      וכן, זה כלפי מטה ועשיתי טעות. אתקן 🙂

  2. דפנה הגב דצמבר 1, 2019 בשעה 5:49 pm

    תודה על הפוסט!
    ובנוגע לעיגול השברים, זה כלפי מטה לפי הדוגמה לא?

  3. מעניין הגב דצמבר 22, 2020 בשעה 5:20 pm

    מעניין איך BABEL ימיר שלמים גדולים כאלה לjs ישן

השארת תגובה

ביטול

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

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

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