قابلیتهای یک Flex Container در بوت استرپ 4
یک Flex Container متداول به این صورت کار میکند:
بر روی یک Flex Container میتوان کلاسهای تعیین جهت را نیز تعریف کرد:
در یک Flex Container امکان تعیین ترتیب عناصر نیز وجود دارد:
همچنین امکان تنظیم فواصل بین آیتمها نیز در یک Flex Container پیش بینی شدهاست:
میتوان نحوهی Wrap المانها را بر اساس فضای خالی در یک Flex Container به صورت زیر تنظیم کرد:
برای تغییر تراز عمودی المانها در یک Flex Container از کلاس align-content استفاده میشود:
یک مثال: بررسی ویژگیهای یک Flex Container
در اینجا ارتفاع container به 100vh تنظیم شدهاست تا کل view-port را پوشش دهد و رنگ آن نیز به bg-info تنظیم شدهاست تا بتوان تغییر محل تراز عمودی را بهتر مشاهده کرد.
در ابتدا کلاس d-flex را به div داخل container اضافه میکنیم:
بلافاصله مشاهده خواهیم کرد که عناصر تعریف شده در طی یک ردیف از چپ به راست نمایش داده میشوند:
و اگر جهت این Flex Container را به صورت صریح مشخص کنیم:
آیتمهای درون آن به صورت یک ستون نمایش داده میشوند:
و یا اگر بخواهیم آیتمها را از راست به چپ به صورت یک ردیف نمایش دهیم میتوان از flex-row-reverse استفاده کرد:
و اگر بجای row در این حالت column را مقدار دهی کنیم:
آیتمها از پایین صفحه شروع خواهند شد. البته در این مثال break-point از نوع sm نیز ذکر شدهاست تا پس از گذر از این اندازهی صفحه، چنین اتفاقی رخ دهد.
و یا اگر بخواهیم آیتمها از راست به چپ در طی یک ردیف، پس از اندازهی صفحهی sm و همچنین در میانهی صفحه ظاهر شوند، میتوان از کلاس justify-content استفاده کرد:
با این خروجی:
و اگر wrap را فعال کنیم:
اگر آیتمها با اندازهی اصلی خودشان، در ردیف جاری جا نشدند، به سطرهای بعدی منتقل خواهند شد.
اگر nowrap را فعال کنیم:
سعی میکند در ردیف جاری، آیتمها را تا حد ممکن کوچک کرده و نمایش دهد:
و با فعالسازی align-content-start، تمام آیتمها را به سمت بالای صفحه هدایت میکند و align-content-end، آنها را از پایین صفحه شروع خواهد کرد:
کنترل آیتمهای قرار گرفتهی درون یک Flex Container در بوت استرپ 4
علاوه بر امکان کنترل ویژگیهای یک Flex Container، اجزای قرار گرفتهی درون آنها را نیز میتوان کنترل کرد و اینکار توسط کلاس align-self میسر است:
این مورد نیز همانند توضیحات کلاس align-self اعمالی به ستونها است که در قسمت قبل بررسی کردیم.
به علاوه در اینجا امکان تعریف floating elements نیز مسیر است که شبیه به دسترسی به امکانات CSS در بوت استرپ است با امکان تنظیم break-points:
کلاسهای تعریف margin و padding در بوت استرپ 4
در بوت استرپ 4 کلاسهای ویژهای برای ایجاد margin و padding بین عناصر در نظر گرفته شدهاند که خلاصهی آنها فرمول زیر است:
در اینجا امکان اعمال یک break-point اختیاری نیز وجود دارد. در آخر اندازه ذکر میشود که بین 0 تا 5 متغیر است.
یک مثال: اعمال کلاسهای padding و margin بوت استرپ 4
در اینجا به آیتم Health یک margin-left با اندازهی 3، یک margin بالا و پایین فعال شوندهی پس از sm با اندازهی 3، یک padding پایین با اندازهی 3 و یک padding بالا با اندازهی 5 اضافه شدهاست؛ با این خروجی:
نمایش و مخفی سازی عناصر در بوت استرپ 4
کلاس invisible سبب میشود تا المانی در صفحه نمایش داده نشود، اما این المان همچنان فضای اختصاصی خود را خواهد داشت. کلاس visible به معنای نمایان بودن المانی تنها برای screen readers است (دستگاههای کمکی معلولها).
اما روش اصلی نمایش و یا مخفی سازی عناصر در بوت استرپ 4، استفاده از خاصیت display است:
امکان تعیین اندازهی عناصر در بوت استرپ 4
بوت استرپ 4 تعدادی کلاس ویژه را برای تعیین اندازهی عناصر نیز افزودهاست:
در اینجا w=width، h=height، mw=max-height و mh=max-height است با مقادیر 25، 50، 75 و 100 و مقدار پیشفرض آن 100 است (یعنی پوشاندن کل container).
کدهای کامل این قسمت را از اینجا میتوانید دریافت کنید: Bootstrap4_06.zip
یک Flex Container متداول به این صورت کار میکند:
این کلاسها که موارد داخل پرانتز آنها اختیاری است، المان را تبدیل به یک المان Flexbox میکنند. حالت نمایشی پیشفرض آنها block است؛ اما اگر نیاز بود میتوان آنها را تبدیل به in-line نیز کرد. بنابراین سادهترین Flex Container را میتوان با افزودن کلاس d-flex ایجاد کرد.
بر روی یک Flex Container میتوان کلاسهای تعیین جهت را نیز تعریف کرد:
به این ترتیب میتوان آیتمها را به صورت ردیفها و یا ستونهایی، نمایش داد. مقدار row در اینجا به صورت پیشفرض اعمال میشود. بنابراین ذکر کلاس خالی flex به معنای قرار دادن المانها در طی چندین ردیف در صفحه است. در اینجا استفادهی از reverse، نمایش المانها را از راست به چپ میسر میکند.
در یک Flex Container امکان تعیین ترتیب عناصر نیز وجود دارد:
این مورد را در مطلب «طرحبندی صفحات وب با بوت استرپ 4 - قسمت دوم » بررسی کردیم. کلاس order را علاوه بر ستونها، بر روی هر دربرگیرندهای که دارای کلاس d-flex است نیز میتوان اعمال کرد.
همچنین امکان تنظیم فواصل بین آیتمها نیز در یک Flex Container پیش بینی شدهاست:
برای مثال استفادهی از مقدار تراز center، روش بسیار مناسبی برای قرار دادن عناصر، در میانهی افقی صفحه است. این مورد را نیز در قسمت قبل بررسی کردیم.
میتوان نحوهی Wrap المانها را بر اساس فضای خالی در یک Flex Container به صورت زیر تنظیم کرد:
که در اینجا دو مقدار wrap و nowrap قابل تنظیم است. در حالت wrap، اگر آیتمها با اندازهی خودشان در ردیف جاری جا نشدند، به سطر یا سطرهای بعدی منتقل خواهند شد. حالت پیشفرض nowrap است.
برای تغییر تراز عمودی المانها در یک Flex Container از کلاس align-content استفاده میشود:
این مورد را نیز در قسمت قبل بررسی کردیم و همانند کار با ستونها میباشد.
یک مثال: بررسی ویژگیهای یک Flex Container
<head> <style> .item { background: #f0ad4e; text-align: center; width: 150px; height: 30px; border: 1px solid white; } </style> </head> <body> <div class="container bg-danger"> <div class="bg-info" style="height:100vh"> <div class="item">Exotic</div> <div class="item">Grooming</div> <div class="item">Health</div> <div class="item">Nutrition</div> <div class="item">Pests</div> <div class="item">Vaccinations</div> </div> </div> </body>
در ابتدا کلاس d-flex را به div داخل container اضافه میکنیم:
<div class="bg-info d-flex" style="height:100vh">
و اگر جهت این Flex Container را به صورت صریح مشخص کنیم:
<div class="bg-info d-flex flex-column" style="height:100vh">
و یا اگر بخواهیم آیتمها را از راست به چپ به صورت یک ردیف نمایش دهیم میتوان از flex-row-reverse استفاده کرد:
<div class="bg-info d-flex flex-row-reverse" style="height:100vh">
و اگر بجای row در این حالت column را مقدار دهی کنیم:
<div class="bg-info d-flex flex-sm-column-reverse" style="height:100vh">
آیتمها از پایین صفحه شروع خواهند شد. البته در این مثال break-point از نوع sm نیز ذکر شدهاست تا پس از گذر از این اندازهی صفحه، چنین اتفاقی رخ دهد.
و یا اگر بخواهیم آیتمها از راست به چپ در طی یک ردیف، پس از اندازهی صفحهی sm و همچنین در میانهی صفحه ظاهر شوند، میتوان از کلاس justify-content استفاده کرد:
<div class="bg-info d-flex flex-sm-row-reverse justify-content-center" style="height:100vh">
و اگر wrap را فعال کنیم:
<div class="bg-info d-flex flex-sm-row-reverse justify-content-center flex-wrap" style="height:100vh">
اگر آیتمها با اندازهی اصلی خودشان، در ردیف جاری جا نشدند، به سطرهای بعدی منتقل خواهند شد.
اگر nowrap را فعال کنیم:
<div class="bg-info d-flex flex-sm-row-reverse justify-content-center flex-nowrap" style="height:100vh">
و با فعالسازی align-content-start، تمام آیتمها را به سمت بالای صفحه هدایت میکند و align-content-end، آنها را از پایین صفحه شروع خواهد کرد:
<div class="bg-info d-flex flex-sm-row-reverse justify-content-center flex-wrap align-content-start" style="height:100vh">
کنترل آیتمهای قرار گرفتهی درون یک Flex Container در بوت استرپ 4
علاوه بر امکان کنترل ویژگیهای یک Flex Container، اجزای قرار گرفتهی درون آنها را نیز میتوان کنترل کرد و اینکار توسط کلاس align-self میسر است:
این مورد نیز همانند توضیحات کلاس align-self اعمالی به ستونها است که در قسمت قبل بررسی کردیم.
به علاوه در اینجا امکان تعریف floating elements نیز مسیر است که شبیه به دسترسی به امکانات CSS در بوت استرپ است با امکان تنظیم break-points:
فرض کنید به تمام آیتمهای داخل Flex Container کلاس float-left را اضافه کردهایم. در این حالت Container قابلیت ردیابی اندازهی این آیتمها را از دست میدهد. به همین جهت با اعمال کلاس clearfix بوت استرپ به container، مجددا امکان ردیابی این آیتمها را پیدا میکند.
کلاسهای تعریف margin و padding در بوت استرپ 4
در بوت استرپ 4 کلاسهای ویژهای برای ایجاد margin و padding بین عناصر در نظر گرفته شدهاند که خلاصهی آنها فرمول زیر است:
ابتدا با تعریف یک خاصیت شروع میشود؛ مانند m یا p، برای کنترل margin و padding. سپس لبهای که باید به آن اعمال شود بدون فاصله و یا - ذکر میشود؛ مانند mt به معنای margin-top. در این فرمول x به معنای اعمال همزمان به چپ و راست است و y به معنای اعمال همزمان به بالا و پایین و اگر میخواهید آیتمهای کناری آیتم جاری را به دو طرف لبهها هدایت کنید از mx-auto استفاده کنید.
در اینجا امکان اعمال یک break-point اختیاری نیز وجود دارد. در آخر اندازه ذکر میشود که بین 0 تا 5 متغیر است.
یک مثال: اعمال کلاسهای padding و margin بوت استرپ 4
<head> <style> .item { background: #f0ad4e; text-align: center; border: 1px solid white; } </style> </head> <body> <div class="container bg-danger"> <div class="bg-info d-flex"> <div class="item">Exotic</div> <div class="item">Grooming</div> <div class="item bg-danger ml-3 my-sm-3 pb-3 pt-5">Health</div> <div class="item">Nutrition</div> <div class="item">Pests</div> <div class="item">Vaccinations</div> </div> </div> </body>
نمایش و مخفی سازی عناصر در بوت استرپ 4
کلاس invisible سبب میشود تا المانی در صفحه نمایش داده نشود، اما این المان همچنان فضای اختصاصی خود را خواهد داشت. کلاس visible به معنای نمایان بودن المانی تنها برای screen readers است (دستگاههای کمکی معلولها).
اما روش اصلی نمایش و یا مخفی سازی عناصر در بوت استرپ 4، استفاده از خاصیت display است:
برای مثال با انتساب کلاس d-sm-none به المانی، میتوان سبب مخفی شدن آن پس از گذر از sm شد.
امکان تعیین اندازهی عناصر در بوت استرپ 4
بوت استرپ 4 تعدادی کلاس ویژه را برای تعیین اندازهی عناصر نیز افزودهاست:
در اینجا w=width، h=height، mw=max-height و mh=max-height است با مقادیر 25، 50، 75 و 100 و مقدار پیشفرض آن 100 است (یعنی پوشاندن کل container).
کدهای کامل این قسمت را از اینجا میتوانید دریافت کنید: Bootstrap4_06.zip