FlexBox הוא קונטיינר שמסדר פריטים בכיוון אחד. הוא יכול לשנות את הגודל, להוסיף גלישת טקסט, ליישר ולחלק את הרווח בין הפריטים כדי למלא את השטח הזמין בצורה אופטימלית. זה פריסה שימושית לפריטים בגדלים שונים ולשינוי הגודל של פריטים כשהשטח הזמין משתנה.
בעזרת FlexBox, אפשר:
- שליטה באופן ההגדלה וההקטנה של הפריטים כדי למלא את השטח הזמין
- העברת פריטים לשורות או לעמודות חדשות כשאין מספיק מקום בשורות או בעמודות הקיימות
- חלוקת רווחים נוספים בין פריטים באמצעות הגדרות קבועות מראש
מתי כדאי להשתמש ב-FlexBox
התג FlexBox משמש בדרך כלל להצגת מספר קטן של פריטים בתוך פריסת מסך כוללת. לפריסת מסך כוללת, בדרך כלל עדיף להשתמש ב-Grid. FlexBox לא תומך בטעינה עצלה של פריטים. כדי להציג מספרים גדולים של פריטים, משתמשים ברשימות וברשתות עצלות. אם אתם צריכים לעטוף פריטים, השתמשו ב-FlexBox במקום ב-FlowRow וב-FlowColumn.
הסברים על המונחים
FlexBox מסדר את הפריטים שלו בשורות אופקיות או אנכיות. הכיוון של הקווים האלה קובע את הציר הראשי. ציר שמאונך לציר הראשי נקרא ציר משני. האורך של FlexBox לאורך הציר הראשי נקרא הגודל הראשי. האורך המתאים של הציר הניצב נקרא גודל הציר הניצב. הגדלים והצירים האלה הם הבסיס להתנהגות של FlexBox.
FlexBox הוא Row.
FlexBox.Column
החלת מאפיינים
יש שתי דרכים להחיל מאפייני FlexBox:
- למאגר התגים
FlexBoxבאמצעותFlexBox(config) - לפריט בתוך
FlexBoxבאמצעותModifier.flex
מאפייני מאגר ( |
מאפייני פריט ( |
|---|---|
מידע נוסף על המאפיינים האלה זמין במאמר הגדרת התנהגות של מאגרי תגים. |
מידע נוסף על המאפיינים האלה זמין במאמר הגדרת התנהגות של פריטים. |
הסבר על אלגוריתם הפריסה FlexBox
אחת מהתכונות החזקות ביותר של FlexBox היא היכולת לשנות את הגודל של רכיבי הצאצא שלו כך שיתאימו בצורה הטובה ביותר למרחב שזמין לו. הבנה של האופן שבו FlexBox עושה זאת יכולה לעזור לכם להגדיר מאפיינים של FlexBox כדי לבצע אופטימיזציה של ממשק המשתמש לכל הגדלים האפשריים.
אלגוריתם הפריסה של FlexBox פועל באופן הבא:
חישוב גודל הבסיס של רכיב צאצא: משתמשים בערך
basisשל רכיב הצאצא כדי לחשב את הגודל ההתחלתי שלו לאורך הציר הראשי לפני חלוקת השטח הנוסף.מיון הילדים: מיון הילדים לפי ערכי
order, אם יש כאלה.יצירת שורות: לכל צאצא, המערכת בודקת אם הגודל ההתחלתי שלו בתוספת
gapיתאים לשטח שנותר בשורה הנוכחית. אם כן, צריך להוסיף את הילד או הילדה לרשימת ההמתנה. אם לא, מציבים אותו בשורה חדשה אם הגלישה מופעלת, או מציבים את הפריט בשורה הנוכחית, שם הוא יחרוג מהגבולות (הוא יוסתר חלקית על ידי הקצה של הקונטיינר).יישור או שינוי גודל של פריטים בציר הראשי: לכל שורה, מחלקים את הרווח הנוסף בין הפריטים או משנים את הגודל שלהם או מיישרים אותם.
יישור או שינוי גודל של פריטים בציר המשני: לכל שורה, אפשר למתוח או ליישר את הפריטים והשורות כדי לחלק את הרווח הנוסף ביניהם.
עכשיו, אחרי שהכרתם את המושגים של FlexBox, אתם יכולים לעבור אל תחילת העבודה כדי ליצור FlexBox בסיסי.