במאמר הזה נסביר על ההבדלים בין מסגרות לספריות בהקשר של סביבה של JavaScript בצד הלקוח, שהיא הקוד שפועל בדפדפן האינטרנט. עם זאת, חלק מהנקודות שמפורטות במאמר הזה רלוונטיות גם לסביבות אחרות, כי ספריות ו-frameworks הם חלק מתחומים רבים של הנדסת תוכנה, כמו פיתוח אפליקציות מקוריות לנייד.
הדיונים בפוסט הזה מתמקדים בהבדלים האיכותיים בין ספריות לבין מסגרות, ולא בהבדלים הכמותיים. לדוגמה:
- כמותית: בדרך כלל, המסגרות פועלות לפי העיקרון של הפיכת השליטה.
- איכותית: הניסיון עם המסגרת יכול למשוך מעסיקים פוטנציאליים יותר כשמחפשים עבודה.
למה כדאי ללמוד על ספריות ועל מסגרות?
השימוש בספריות ובמסגרות של JavaScript נפוץ באינטרנט. נראה שכל אתר אחר משתמש בקוד של צד שלישי כחלק מהמשאבים של JavaScript. המשקל של דפי האינטרנט הולך ונעשה גדול יותר עם הזמן, ומשפיע על המשתמשים. JavaScript הוא גורם משמעותי במשקל הכולל של הדף, ואותו JavaScript כולל בדרך כלל ספריות ותבניות של צד שלישי.
לא מספיק להגיד "כדאי להפסיק להשתמש במסגרות JavaScript", כי למסגרות יש יתרונות רבים למפתחים. בין היתר, מסגרות יכולות לעזור לכם לכתוב קוד ביעילות ולהציג תכונות במהירות. במקום זאת, כדאי לקבל מידע כדי שתוכלו לקבל החלטה מושכלת כשהזמן יגיע.
השאלה "האם כדאי להשתמש בספרייה או ב-framework היום?" היא לא שאלה נפוצה. ספריות ופלטפורמות הן שתי דברים שונים מאוד. עם זאת, לרוב משתמשים בספריות ובמסגרות יחד, וככל שיהיו לכם יותר ידע על שתיהן, כך תהיה לכם יותר אפשרות לקבל החלטות מושכלות לגבי השימוש בהן.
דוגמאות לספריות ולמסגרות (frameworks)
יכול להיות שתבחינו בקוד של צד שלישי בשמות אחרים, כמו ווידג'טים, פלאגינים, פוליפולים או חבילות. עם זאת, בדרך כלל כולן נכללות בקטגוריה של ספרייה או מסגרת. באופן כללי, אפשר לסכם את ההבדל בין השניים באופן הבא:
- בספרייה, קוד האפליקציה קורא לקוד הספרייה.
- כשמשתמשים ב-framework, ה-framework קורא לקוד של האפליקציה.
ספרייה
ספריות הן בדרך כלל פשוטות יותר מסגרות, ומציעות היקף מצומצם של פונקציונליות. אם מעבירים קלט לשיטה ומקבלים פלט, סביר להניח שהשתמשתם בספרייה.
בדוגמה הבאה מוצגת הספרייה lodash
:
import lodash from 'lodash'; // [1]
const result = lodash.capitalize('hello'); // [2]
console.log(result); // Hello
כמו בספריות רבות, מומלץ לקרוא את הקוד הזה ולהבין מה הוא עושה. התהליך פשוט מאוד:
- הצהרת
import
מייבאת את ספריית lodash לתוכנית JavaScript. - השיטה
capitalize()
מופעלת. - מועבר ארגומנט אחד ל-method.
- הערך המוחזר מתועד במשתנה.
Framework
ספריות בדרך כלל קטנות יותר מסגרות, והן תורמות יותר למשקל הכולל של הדף. למעשה, מסגרת יכולה לכלול ספרייה.
בדוגמה הזו מוצגת מסגרת פשוטה ללא ספרייה, שמשתמשת ב-Vue, מסגרת JavaScript פופולרית:
<!-- index.html -->
<div id="main">
{{ message }}
</div>
<script type="module">
import Vue from './node_modules/vue/dist/vue.esm.browser.js';
new Vue({
el: '#main',
data: {
message: 'Hello, world'
}
});
</script>
אם משווים את דוגמת המסגרת הזו לדוגמה הקודמת של הספרייה, אפשר להבחין בהבדלים הבאים:
- קוד המסגרת כולל כמה שיטות ומעביר אותן ל-API משלו.
- למפתחים אין שליטה מלאה על האופן והמועד שבהם מתבצעות הפעולות. לדוגמה, אתם לא צריכים לדאוג לאופן ולמועד שבו Vue כותב את המחרוזת
'Hello, world'
לדף. - יצירת המופע של הכיתה
Vue
גורמת לתופעות לוואי, שהן נפוצות כשמשתמשים במסגרות, בעוד שספרייה עשויה להציע פונקציות טהורות. - במסגרת מוגדרת מערכת תבניות HTML מסוימת, במקום להשתמש במערכת משלכם.
- אם תמשיכו לקרוא את מסמכי התיעוד של Vue framework או את רוב מסמכי התיעוד של מסגרות אחרות, תוכלו לראות איך המסגרות קובעות דפוסי ארכיטקטורה שאפשר להשתמש בהם. מסגרות JavaScript מפחיתות את העומס הקוגניטיבי, כי אתם לא צריכים להבין את הנושא בעצמכם.
מתי כדאי להשתמש בספרייה ומתי כדאי להשתמש ב-framework
אחרי שתסיימו לקרוא את ההשוואות בין ספריות לבין מסגרות, אולי תתחילו להבין מתי כדאי להשתמש בספרייה ומתי במסגרת:
- מסגרת יכולה להפחית את המורכבות עבורכם, המפתחים. כפי שציינו, מסגרת יכולה להסתיר לוגיקה, התנהגות ואפילו דפוסים אדריכליים. האפשרות הזו שימושית במיוחד כשמתחילים פרויקט חדש. ספרייה יכולה לעזור בהתמודדות עם המורכבות, אבל בדרך כלל היא מתמקדת בשימוש חוזר בקוד.
- מחברי המסגרות רוצים לעזור לכם להיות פרודוקטיביים, ולכן הם מפתחים לעיתים קרובות כלים נוספים, תוכנות לניפוי באגים ומדריכים מקיפים, בין היתר, כדי לעזור לכם להשתמש במסגרת בצורה יעילה. גם מחברי הספריות רוצים לעזור לכם להיות פרודוקטיביים, אבל כלים מיוחדים הם נדירים בספריות.
- רוב המסגרות מספקות נקודת התחלה פונקציונלית, כמו שלד או תבנית בסיסית, שיעזרו לכם לפתח אפליקציות אינטרנט במהירות. הספרייה הופכת לחלק מקוד הבסיס שכבר קיים.
- באופן כללי, שימוש במסגרות מוסיף מורכבות לקוד. המורכבות לא תמיד ברורה בהתחלה, אבל היא עשויה להתגלות עם הזמן.
כתזכורת, בדרך כלל לא משווים בין ספרייה לבין מסגרת כי הן דברים שונים שמשמשים למטרות שונות. עם זאת, ככל שתצברו יותר ידע על שתי האפשרויות, כך תוכלו לקבל החלטה מושכלת יותר לגבי האפשרות שמתאימה לכם. בסופו של דבר, ההחלטה אם להשתמש במסגרת או בספרייה תלויה בדרישות שלכם.
החלפה
לא תשנו את הספרייה או המסגרת בכל שבוע. עם זאת, מומלץ להבין את החסרונות של חבילה שמחייבת אתכם להשתמש במערכת האקולוגית שלה. מומלץ גם להבין שהמפתח שמחליט להשתמש בחבילה של צד שלישי אחראי במידה מסוימת ליצירת קישור רופף בין החבילה לבין קוד המקור של האפליקציה.
קשה יותר להסיר חבילה שמקושרת לקוד המקור ולהחליף אותה בחבילה אחרת. יכול להיות שתצטרכו להחליף חבילה במקרים הבאים:
- אתם צריכים לבצע עדכונים לחבילה שלא מתבצעת יותר עליה תחזוקה.
- גיליתם שהחבילה מכילה יותר מדי באגים כדי שתוכלו לעבוד איתה.
- שמעתם על חבילת שירות חדשה שמתאימה יותר לצרכים שלכם.
- דרישות המוצר השתנו ואתם כבר לא צריכים את החבילה.
עיין בדוגמה זו:
// header.js file
import color from '@package/set-color';
color('header', 'dark');
// article.js file
import color from '@package/set-color';
color('.article-post', 'dark');
// footer.js file
import color from '@package/set-color';
color('.footer-container', 'dark');
בדוגמה הקודמת, חבילת הצד השלישי @package/set-color
מופיעה בשלושה קבצים נפרדים. אם אתם עובדים על הקוד הזה ואתם צריכים להחליף את חבילת הצד השלישי, עליכם לעדכן את הקוד בשלושה מקומות.
לחלופין, אפשר לפשט את התחזוקה ולהעביר את השימוש בספרייה למקום אחד, כפי שמוצג בדוגמה הבאה:
// lib/set-color.js file
import color from '@package/set-color';
export default function color(element, theme = 'dark') {
color(element, theme);
}
// header.js file
import color from './lib/set-color.js';
color('header');
// article.js file
import color from './lib/set-color.js';
color('.article-post');
// footer.js file
import color from './lib/set-color.js';
color('.footer-container');
בדוגמה הקודמת, השימוש הישיר בספרייה מופשט. לכן, אם צריך להחליף את חבילת הצד השלישי, צריך לעדכן רק קובץ אחד. בנוסף, עכשיו קל יותר לעבוד עם הקוד כי קובץ set-color.js
הפנימי מגדיר ערכת צבעים שמוגדרת כברירת מחדל.
קלות השימוש
יכול להיות למסגרת ממשק API מורכב, אבל יכול להיות שהיא תציע כלים למפתחים שיקלו על השימוש בה באופן כללי. קלילות השימוש מבוססת על גורמים רבים ויכולה להיות סובייקטיבית מאוד. יכול להיות שיהיה קשה להשתמש ב-framework כי:
- למסגרת יש ממשק API מורכב מטבעו.
- התיעוד של המסגרת לא מקיף, ופתרון בעיות מחייב הרבה ניסוי וטעייה.
- המסגרת כוללת שיטות שלא מוכרות לכם ולצוות שלכם.
מסגרות יכולות לצמצם את האתגרים האלה באמצעות שיטות מומלצות נפוצות, כמו:
- המסגרת כוללת כלים למפתחים ולאבחון, שמקלים על ניפוי הבאגים.
- ל-Framework יש קהילה פעילה של מפתחים שמשתפים פעולה ביצירת מסמכי עזרה, מדריכים, סרטונים ומאמרים חינמיים. אחרי שקוראים את התוכן הזה, אפשר להשתמש בפלטפורמה בצורה יעילה.
- המסגרת כוללת ממשק API שתואם למוסכמות תכנות נפוצות. אתם עובדים ביעילות עם המסגרת כי למדתם כללי התנהגות כאלה בעבר, ויש לכם היכרות רבה יותר עם סגנונות תכנות.
בדרך כלל, הנקודות האלה משויכות למסגרות, אבל אפשר לשייך אותן גם לספריות. לדוגמה, ספריית JavaScript D3.js חזקה ויש לה סביבה עסקית גדולה שמציעה סדנאות, מדריכים ותיעוד, בין היתר, שכוללים משאבים שמשפיעים על קלות השימוש בה.
בנוסף, בדרך כלל מסגרת קובעת ארכיטקטורה לאפליקציית האינטרנט, בעוד שספרייה בדרך כלל תואמת לארכיטקטורה הקיימת, לא משנה מה היא.
ביצועים
באופן כללי, מסגרות יכולות להשפיע על הביצועים יותר מאשר ספריות, אבל יש יוצאים מן הכלל. ביצועי האתר הם תחום עצום עם הרבה נושאים, ולכן בקטעים האלה נתייחס לשני נושאים חשובים: ניעור עצים ועדכוני תוכנה.
Tree shaking
קיבוץ הוא רק היבט אחד של ביצועי האתר, אבל יש לו השפעה רבה על הביצועים, במיוחד בספריות גדולות יותר. השימוש ב-tree shaking במהלך הייבוא והייצוא עוזר לשפר את הביצועים, כי הוא מוצא קוד שאינו נחוץ לאפליקציה ומסיר אותו.
כשמקבצים קוד JavaScript, יש שלב שימושי שנקרא 'ניפוי עצים', שהוא אופטימיזציה חשובה של הביצועים שאפשר לבצע בקוד. עם זאת, קל יותר לבצע את הפעולה הזו בספריות מאשר במסגרות.
כשמייבאים קוד של צד שלישי לקוד המקור, בדרך כלל מקובצים את הקוד בקובץ פלט אחד או בכמה קבצים. לדוגמה, הקבצים header.js
, footer.js
ו-sidebar.js
משולבים בקובץ output.js
, שהוא קובץ הפלט שאתם טוענים באפליקציית האינטרנט.
כדי להבין טוב יותר את הרעידה של העץ, כדאי לעיין בדוגמאות הקוד הבאות:
// library.js file
export function add(a, b) {
return a + b;
}
export function subtract(a, b) {
return a - b;
}
// main.js file
import {add} from './library.js';
console.log(add(7, 10));
למטרות הדגמה, דוגמת הקוד של library.js
קטנה באופן מכוון בהשוואה למה שעשוי להופיע בעולם האמיתי, שבו הספרייה יכולה להכיל אלפי שורות.
תהליך חבילה פשוט עשוי לייצא את הקוד עם הפלט הזה:
// output.js file
function add(a, b) {
return a + b;
}
function subtract(a, b) {
return a - b;
}
console.log(add(7, 10));
למרות שאין צורך בפונקציה subtract()
באפליקציה הזו, היא עדיין כלולה בחבילה הסופית. קוד מיותר כזה מגדיל את גודל ההורדה, את זמן הניתוח וההדרכה ואת עלויות הביצוע שהמשתמשים צריכים לשלם. גישה בסיסית של ניעור עצים מסירה את הקוד הלא פעיל ומפיקה את הפלט הזה:
// output.js file
function add(a, b) {
return a + b;
}
console.log(add(7, 10));
שימו לב שהקוד קצר ותמציתי יותר. בדוגמה הזו, שיפור הביצועים הוא זניח, אבל באפליקציה אמיתית שבה הספרייה מכילה אלפי שורות, ההשפעה על הביצועים יכולה להיות משמעותית הרבה יותר. מעניין לציין שכלי ה-bundle המודרניים, כמו Parcel, Webpack ו-Rollup, עוברים צעד נוסף כי הם משלבים בין דחיסה לבין הסרת קוד לא נדרש (tree shaking) כדי ליצור חבילת bundle שעברה אופטימיזציה ברמה גבוהה. כדי להמחיש את היעילות של כלי ה-bundle, השתמשנו ב-Parcel כדי ליצור קובץ bundle עם דוגמאות הקוד הקודמות. Parcel הסיר את כל הקוד שלא בשימוש וייצא את המודול היחיד הזה:
console.log(7+10);
Parcel מספיק חכם כדי להסיר הצהרות על ייבוא, הגדרות פונקציות והתנהגות, בין היתר, כדי ליצור קוד מותאם במיוחד.
קיבוץ הוא רק היבט אחד של ביצועי האתר, אבל יש לו השפעה רבה על הביצועים, במיוחד בספריות גדולות יותר. בדרך כלל קל יותר לבצע ריקון עץ עם ספריות מאשר עם מסגרות.
עדכוני תוכנה
בספריות ובמסגרות רבות, עדכוני תוכנה מוסיפים פונקציונליות, מתקנים באגים ובסופו של דבר הגודל שלהם גדל עם הזמן. לא תמיד צריך להוריד עדכונים, אבל אם העדכונים כוללים תיקוני באגים, שיפורים רצויים בתכונות או תיקוני אבטחה, מומלץ לעדכן. עם זאת, ככל ששולחים יותר נתונים דרך החיבור, הביצועים של האפליקציה נפגעים וההשפעה של הביצועים על חוויית המשתמש גדלה.
אם הספרייה גדלה, אפשר להשתמש ב-tree shaking כדי לצמצם את הגדילה. לחלופין, אפשר להשתמש בחלופה קטנה יותר לספריית JavaScript. מידע נוסף זמין במאמר החלפה.
ככל שהמסגרת גדלה, לא רק שהרעידת העץ הופכת לאתגר גדול יותר, אלא גם קשה יותר להחליף מסגרת אחת במסגרת אחרת. מידע נוסף זמין במאמר החלפה.
כשירות תעסוקתית
ידוע לכולם שיש לחברות רבות דרישות נוקשות למפתחים שמכירים מסגרת עבודה מסוימת. יכול להיות שהם יתעלמו מהידע שלכם ביסודות האינטרנט ויתמקד רק בידע הספציפי שלכם ב-JavaScript framework מסוים. נכון או לא נכון, זו המציאות בתחומים רבים.
ידע בכמה ספריות JavaScript לא יזיק לבקשה שלכם לקבלת עבודה, אבל אין הרבה ערובה לכך שהוא יעזור לכם להתבלט. אם אתם מכירים היטב כמה מסגרות JavaScript פופולריות, סביר להניח שבעלי עסקים יראו את הידע הזה כמשהו חיובי בשוק העבודה הנוכחי למפתחי אתרים. ארגונים גדולים מסוימים תקועים עם מסגרות JavaScript ישנות מאוד, ויכול להיות שהם אפילו מחפשים נואשות מועמדים שמתמצאים במסגרות כאלה.
אתם יכולים להשתמש בסוד הפתוח הזה לטובתכם. עם זאת, חשוב לגשת לשוק העבודה בזהירות תוך התחשבות בשיקולים הבאים:
- חשוב לזכור שאם תעבירו חלק גדול מהקריירה שלכם עם מסגרת אחת בלבד, יכול להיות שתפספסו חוויות למידה עם מסגרות אחרות ומודרניות יותר.
- נניח שמפתח לא מבין לעומק את העקרונות הבסיסיים של פיתוח תוכנה או פיתוח אינטרנט, אבל הוא עובד כמפתח של מסגרת עבודה. המפתח הזה לא כותב קוד יעיל, ויכול להיות שתתקשו לעבוד על קוד בסיס כזה. במקרים מסוימים, התרחיש הזה עלול להוביל לתחושת שחיקה. לדוגמה, יכול להיות שתצטרכו לבצע רפאקציה של הקוד או לשפר את הביצועים שלו כי הוא איטי.
- כשאתם מתחילים ללמוד פיתוח אתרים, הדרך הטובה ביותר היא להתמקד ביסודות של פיתוח אתרים, פיתוח תוכנה והנדסת תוכנה. בסיס חזק כזה עוזר לכם ללמוד כל מסגרת JavaScript במהירות וביעילות.
סיכום
תודה על המאמץ שהשקעת בהבנת ההבדלים בין מסגרות לספריות של JavaScript. לא תצטרכו לבחור מסגרות או ספריות לעיתים קרובות, אלא אם אתם עובדים בפרויקטים בשטח ריק או בתור יועצים. עם זאת, כשמתעוררות החלטות כאלה, ככל שיש לכם יותר ידע בנושא, כך ההחלטה תהיה מושכלת יותר.
כפי שלמדתם, הבחירה שלכם בפלטפורמה – ובמקרים מסוימים, הבחירה בספרייה – יכולה להשפיע באופן משמעותי על חוויית הפיתוח ועל משתמשי הקצה, למשל בנושא ביצועים.