הבלוג של ינון פרק

טיפים קצרים וחדשות למתכנתים

בואו נלמד את המחשב שפה חדשה

08/10/2019

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

הפקודה הראשונה שחשוב להכיר היא locale. מפעילים אותה עם -a כדי לקבל רשימה של כל השפות שהמערכת שלכם מכירה:

$ locale -a
C
C.UTF-8
en_US.utf8
POSIX

בשביל ללמד את המחשב שפה חדשה נצטרך להוסיף את קבצי ה Locale שמתאימים לשפה זו. הקובץ /etc/locale.gen כולל רשימה של קבצי locale שאפשר להתקין. רוב השמות שם יהיו בהערה ואתם יכולים פשוט להוציא מהערה את השפה שאתם רוצים להוסיף למערכת, או להוסיף שורה חדשה בסוף הקובץ. אני לומד צרפתית אז אוציא אותה מהערה:

fr_FR.UTF-8 UTF-8

אחרי זה מפעילים את הפקודה locale-gen כדי להתקין את קבצי השפה החדשים:

$ locale-gen
Generating locales (this might take a while)...
  fr_FR.UTF-8... done
  en_US.UTF-8... done
Generation complete.

ונשמח לגלות שהשפה הותקנה באמצעות קריאה נוספת ל locale:

$ locale -a
C
C.UTF-8
en_US.utf8
fr_FR.utf8
POSIX

עד לפה היינו צריכים להריץ את כל הפקודות בתור מנהל מערכת (משתמש root) כי ביצענו שינויים גלובאליים במערכת. עכשיו שהשפה מותקנת אפשר לחזור לעבוד כמשתמש רגיל. ביוניקס כל משתמש יכול לקבוע לעצמו באיזה שפה ה Shell יופיע, אבל רק מנהל המערכת יכול להתקין או להסיר שפות בצורה גלובאלית.

כמשתמש רגיל הפקודה locale מציגה את המידע לגבי השפה הנוכחית שלנו:

$ locale
LANG=en_US.UTF-8
LANGUAGE=
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=

בשביל לשנות שפה כל מה שצריך הוא להגדיר משתני סביבה בשם LANG ו LC_CTYPE. אני רוצה שהשינוי יהיה קבוע לכן אכניס את שתי השורות הבאות לקובץ ה ~/.profile שלי:

export LANG=fr_FR.utf-8
export LC_CTYPE=fr_FR.utf-8

ו... voilà המחשב מתחיל לדבר צרפתית:

$ date
lundi 7 octobre 2019, 14:38:29 (UTC+0000)

זה לא יצליח

07/10/2019

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

״עזוב אותך זה לא יצליח״

״דבר איתי עוד חודשיים כשתתייאש״

״זה הרבה יותר קשה ממה שנדמה לך״

״כל הכבוד על האומץ״

״לא חבל לוותר על מה שכבר יש לך?״

״אולי תתחיל עם משהו יותר קטן?״

והאמת אני מבין. אני גם כזה. אם יבוא בן אדם זה ויגיד שמחר הוא מתכנן להתחיל ללמוד פיתוח Front End והוא הולך לעזוב את העבודה, לקחת הלוואה ולהירשם לקורס... וואלה גם אני הייתי סקפטי. גם אני הייתי מניח לבחור יד על הכתף ואומר ככה ברוח טובה ״אולי תתחיל עם משהו יותר קטן?״ או ״כל הכבוד על האומץ״. חוסר האמון שלנו באנשים אחרים הוא מובנה, עתיק ומבוסס על המון המון סיבות טובות.

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

במקום לחכות לאישור של כל העולם מספיק להסתכל על אלה שכבר הצליחו ולזכור שגם הם שמעו בדיוק את אותם דברים מהחברים שלהם בתחילת המסלול.

עדכוני וובינרים לאוקטובר - החודש של ריאקט

06/10/2019

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

השבוע ביום חמישי אעביר וובינר של שעה על useContext ו useReducer. נראה למה פונקציות אלה טובות וכמה תבניות טובות של שימוש בהן. פרטים והרשמה בקישור.

שבוע הבא נשארים בסוכה ולכן שבוע אחרי זה יהיה וובינר שני על React Hooks הפעם על הפונקציות useMemo ו useCallback. נראה איך הן עוזרות לשפר ביצועים ואיך לזהות מתי כדאי להשתמש בהן. פרטים והרשמה בקישור.

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

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

איך לחזור לשיגרת לימודים אחרי הפסקה

05/10/2019

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

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

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

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

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

  3. הרגלים נמחקים אפילו יותר מהר מידע.

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

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

  1. להכיר באתגרים. להבין שאותם הדברים שגרמו לנו לרצות ללמוד בהתחלה עדיין רלוונטים וששווה לעשות את המאמץ.

  2. לא לצפות לחזור מיד לאותה רמה שהיתה לפני החג. לא להיבהל כשאתם לא מצליחים לפתור תרגילים שכבר הצלחתם בקלות בעבר, או שאתם אפילו לא מבינים קוד שכבר כתבתם בעבר. זה נורמלי.

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

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

החלפת מודולים HMR

04/10/2019

אחת הפונקציות הכי אהובות ב Webpack במצב פיתוח נקראת HMR או בשמה המלא Hot Module Replacement. הרעיון הוא החלפת רכיבים במערכת תוך כדי שהמערכת פועלת ובלי לטעון מחדש את העמוד.

המשך קריאה

שימוש ב Browser Cache בפרויקט Webpack

03/10/2019

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

המשך קריאה

שימוש ב Scss בפרויקט Webpack

02/10/2019

פיתוח פרויקט באמצעות Webpack אומר שאנחנו יכולים להריץ קוד על כל אחד מהקבצים שאנחנו טוענים. באחד הפרקים הקודמים בסידרה למדנו על Babel וראינו איך לתרגם קבצי JavaScript בעזרתו. היום אני רוצה לדבר על Scss ואיך להשתמש ב Webpack כדי לתרגם קבצי Scss לקבצי CSS רגילים.

המשך קריאה

הפלאגין HTML Webpack Plugin

01/10/2019

בפוסטים הקודמים בסידרה על וובפאק השתמשתי ב HTML Webpack Plugin כדי ליצור באופן אוטומטי קובץ HTML עבור הפרויקט שלי. לפלאגין זה יש המון אופציות שהופכות אותו ליעיל גם בפרויקטי משחק קטנים וגם בפרויקטים אמיתיים ואני רוצה לעבור על כמה מהן.

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

המשך קריאה

טיפול בקישורים בקבצי ה CSS

30/09/2019

ראינו איך css-loader מטפל בשבילנו בקבצי CSS שטוענים קבצי CSS אחרים בעזרת import, ואיך כל פקודות ה CSS של כל הקבצים מתחברות יחד לקובץ פלט אחד. קבצי CSS יכולים לטעון גם דברים חיצוניים נוספים כלומר תמונות וגופנים. בפוסט זה ארצה לטפל גם בהם.

המשך קריאה

טעינת קבצי CSS מתוך פרויקט Webpack

29/09/2019

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

המשך קריאה