Na.Ka
Na.Ka
خواندن ۹ دقیقه·۲ سال پیش

FlexBox چیست ؟ ماژولی مبتنی بر CSS برای طراحی های یک بعدی

FlexBox چیست؟

طراحی سایت بسیار جذاب و ساده است و امروزه افراد زیادی قادر هستند سایت شخصی خود را بدون نیاز به برنامه نویسان حرفه‌ای طراحی کنند. برای یک طراحی خوب، تسلط به CSS ضروری به نظر می‌رسد زیرا امکانات زیادی در طراحی به شما می‌دهد. در این مطلب به سراغ یکی از ماژول‌های مهم CSS می‌رویم و یاد می‌گیریم که FlexBox چیست؟ و چه کاربردی در طراحی سایت دارد.

FlexBox چیست؟

FlexBox یکی از ماژول‌های CSS 3 است که کار را در طراحی وب بسیار ساده کرده و نمای تازه‌ای به صفحات HTML می‌بخشد. این ماژول، مدلی برای طراحی‌های تک‌بعدی و نمایش عناصر موجود در صفحه‌ی وب است که برای نصب آن به وابستگی (Dependency) خاصی نیازی نیست.

طراحی صفحات برای نمایش آیتم‌های یک ستونه و یا دو ستونه کار سختی نیست اما با افزایش این بخش‌ها، کار کمی مشکل می‌شود که این مشکل، با استفاده از ماژول FlexBox به راحتی قابل حل است. FlexBox در طراحی‌های واکنش‌گرا (Responsive) کارایی زیادی دارد؛ چرا که با چیدن آیتم‌ها (Flex Item) درون یک سطر یا ستون در قالب نگه‌دارنده (Flex Container)، به طور خودکار عناصر طراحی را با اندازه‌ی صفحه منطبق کرده و مشکلاتی مانند Float یا WhiteSpace را برطرف می‌کند.

بدین ترتیب با استفاده از ماژول FlexBox می‌توان طراحی چند سطری و یا چند ستونی را با زحمت کمتری انجام داد و بهتر آن را مدیریت کرد.

تفاوت CSS Grid با FlexBox چیست؟

هرکدام از این ماژول‌ها برای طراحی واکنش‌گرای صفحات به کار می‌روند و حتی در کنار یکدیگر قابل استفاده هستند. FlexBox و Grid شباهت‌های زیادی دارند و دو مورد از بهترین مدل‌های طراحی محسوب می‌شوند اما تفاوت‌هایی نیز دارند که قابل اهمیت است. مانند:

تنظیم سطر و ستون ها:

یکی از تفاوت‌های اصلی FlexBox با CSS Grid در مورد بعد است. ما در صفحه‌ی وب معمولا عناصر را به دو حالت تک‌بعدی و دوبعدی در نظر می‌گیریم. مثلا منو‌ی سایت ما را نگاه کنید، این منو به عنوان یک عنصر تک بعدی شناخته می‌شود، یعنی در یک مسیر یا یک جهت قرار گرفته است (فقط در جهت محور طول). برای پیاده‌سازی چنین چیزی بهتر است از FlexBox استفاده کنیم، البته با CSS Grid هم این کار شدنی است اما FlexBox با کد کمتر و کیفیت بهتر این کار را انجام می‌دهد.

در طرف مقابل ساختار دو بعدی را داریم. مثلا منوی بالای صفحه با منوی کنار صفحه یک سایت را کنار یکدیگر به عنوان یک عنصر دوبعدی در نظر بگیرید. یعنی اِلمان‌ها در دو بعد یا دو جهت قرار گرفته اند. در این حالت استفاده از CSS grid توصیه می‌شود. چون سرعت کار را بالا برده و خروجی بهتری می‌دهد.

اولویت در محتوا یا طراحی:

اگر قبل از طراحی محتوای سایت خود را بدانید، استفاده از FlexBox مزیت بزرگی خواهد بود. اما به علت پیچیدگی تعیین اندازه‌ی آیتم‌ها در FlexBox، اگر ابتدا قصد طراحی صفحات را دارید تا بعداً نوع محتوای آن را تعیین کنید، استفاده از CSS Grid اهمیت بیشتری پیدا می‌کند.

پیچیدگی تعیین اندازه‌ی المان‌های طراحی:

FlexBox در واقع عنوانی اختصاری و برگرفته از Flexible Box یا جعبه‌ی منعطف است؛ به این معنی که آیتم‌ها با هر اندازه‌ای می‌توانند درون آن، جا بگیرند. این مسئله هم یکی از نقاط قوت این ابزار است و هم اینکه باعث پیچیدگی تعیین اندازه‌ی آیتم‌ها می‌شود. در حالی که CSS Grid در چنین مواردی کمتر شما را به زحمت می‌اندازد.

نباید فراموش کرد که هیچ کدام از این دو ماژول بر دیگری برتری ندارد و هر کدام در جای خود مناسب و کاربردی هستند. باید با توجه به نیاز، بهترین و مناسب‌ترین ماژول را انتخاب کرد. همچنین می‌توان به طور همزمان از FlexBox و CSS Grid استفاده کرد تا کار با قالب بندی و Layout آسان‌تر شود. با استفاده از کتابخانه‌ی Grid-Flexbox می‌توان از این قابلیت استفاده کرد و هر قالبی را به سادگی به وجود آورد.

برای مقایسه‌ی بهتر ترازبندی در CSS Grid و Flexbox ، می‌توان از سایت Alignment Cheatsheet استفاده کرد. در این سایت این دو با هم مقایسه شده است و تفاوت‌ها و شباهت‌های آن‌ها با تصاویر و مثال‌های متنوع مشخص شده است.

میزان پشتیبانی مرورگرها از Flexbox:

طراحان همیشه به پشتیبانی مرورگرها دقت کرده و صبر می‌کنند تا پشتیبانی مرورگر‌ها از FlexBox به اندازه‌ی کافی بالا برود تا با خیال آسوده از آن استفاده کنند. میزان پشتیبانی مرورگر‌ها از FlexBox در این سایت قابل مشاهده است.

نکته‌ی قابل توجه این است که FlexBox دارای سه syntax یا نگارش است؛ در سال 2009 اولین نگارش FlexBox انتشار یافت و در ادامه در سالهای 2011 و2012 دو نگارش دیگر عرضه شدند. در این سه نگارش، بیشتر خاصیت‌ها با هم فرق دارند:

برای اینکه مرورگر‌های قدیمی هم از FlexBox پشتیبانی کنند، باید از دو نگارش قدیمی FlexBox نیز استفاده کنیم. همچنین بعضی از خاصیت‌ها را برای اینکه برخی مرورگرها پشتیبانی کنند، باید از پیشوند‌ها استفاده کنیم. مثلا برای اینکه به یک المان نگهدارنده مقدار flex را به ویژگی display اختصاص دهیم (در مقاله‌ی آموزش جامع Flexbox در مورد این المان بیشتر توضیح خواهیم داد) باید کد زیر را بنویسیم:

.container{ display: -webkit-box; /* OLD - iOS 6-, Safari 3.1-6 */ display: -moz-box; /* OLD - Firefox 19- (buggy but mostly works) */ display: -ms-flexbox; /* TWEENER - IE 10 */ display: -webkit-flex; /* NEW - Chrome */ display: flex; }

همان‌طور که در بالا معلوم است در این حالت برای تنها یک خاصیت، باید 5 خط کد نوشت. می‌توان برای تمیز شدن و مدیریت این تعاریف از  CSS Preprocessor(پیش پردازنده‌های CSS) استفاده  کرده و تمام خاصیت‌های FlexBox در نگارش‌های مختلف را در یک فایل SCSS به صورت mixin تعریف کنیم. کد زیر بخشی از این فایل را نشان می‌دهد:

//Order @mixin order($value) { -webkit-box-ordinal-group: $value; /* OLD - iOS 6-, Safari 3.1-6 */ -moz-box-ordinal-group: $value; /* OLD - Firefox 19- */ -ms-flex-order: $value; /* TWEENER - IE 10 */ -webkit-order: $value; /* NEW - Chrome */ order: $value; } // JUSTIFY CONTENT METHODS // justify-content: [flex-]start; @mixin justify_content_start() { -webkit-box-pack: start; -moz-box-pack: start; -ms-flex-pack: start; -webkit-justify-content: flex-start; justify-content: flex-start; } // justify content center (main axis centering) @mixin justify_content_center() { -webkit-box-pack: center; -moz-box-pack: center; -ms-flex-pack: center; -webkit-justify-content: center; justify-content: center; }

فایل SCSS اشاره شده را داخل استایل اصلی import کرده و سپس با استفاده از mixinهای این فایل، یک صفحه‌ی واکنش‌گرای ساده را می‌نویسیم:

/* SCSS Code */ @import &quot_flexbox"// Import Flexbox.scss .container{ @include display_flex; @include flex_direction_row; @include flex_wrap_wrap; .item{ @include flex(1); &.header{ @include flex(100%); } &.aside{ @include flex(0 200px); height: 150px; } &.main{ @include flex(1 auto); } &.footer{ @include flex(100%); } } } @media screen and (max-width: 950px) { .container .item{ &.header{ @include order(1); } &.aside{ @include flex(1 auto); &.aside1{@include order(3);} &.aside2{@include order(4);} } &.main{ @include order(2); @include flex(1 100%); } &.footer{@include order(5);} } } @media screen and (max-width: 600px) { .container .item{ &.aside{ @include flex(100%); } } }


<!-- HTML Code --> <div class=&quotcontainer&quot> <div class=&quotitem item1 header&quot>header</div> <div class=&quotitem item2 aside aside1&quot>aside1</div> <div class=&quotitem item3 main&quot>main</div> <div class=&quotitem item4 aside aside2&quot>aside2</div> <div class=&quotitem item5 footer&quot>footer</div> </div>

مزایای استفاده از FlexBox چیست؟

FlexBox نسبت به ابزارهای قبل از خود مثل float که قبلا به طور گسترده توسط طراحان وب استفاده می‌شد، اجازه می‌دهد کدهای استانداردتری نوشته‌ شود که در مرورگرهای مختلف به خوبی کار کنند. این ماژول به جای تمرکز روی راه‌حل‌های پیچیده یا استفاده از ترفندهایی مثل CSS Hacks روی شفافیت طراحی تمرکز دارد.

یکی از مشکلات رایج float این است که با اضافه کردن اِلمان و محتوای جدید به یک بخش از سطر یا ستون، ممکن است لایه بندی ما به هم ریخته و کل آن بخش خراب شود. FlexBox دارای ویژگی‌های بیشتری است که طراحی را آسان‌تر می‌کند. در مقاله‌‌ی آموزش جامع Flexbox، چگونگی استفاده از این ویژگی‌ها را خواهیم آموخت. این ویژگی‌ها عبارتند از:

  • قراردادن المان‌ها کنار یکدیگر یک ردیف بدون نیاز به تعیین اندازه‌ی دقیق پهنا و هم‌تراز سازی نسبت به المان نگهدارنده
  • تغییر ترتیب المان‌ها به آسانی امکان‌پذیر است.
  • اگر برای عنصرهایی که در یک خط قرار گرفتن جای کافی نباشد به راحتی عنصر آخر به صورت خودکار در ردیف بعد قرار می‌گیرد. همچنین تعیین اندازه‌ی یک المان نسبت به اندازه‌ی المان نگهدارنده به‌صورت واکنش‌گرا ممکن است.
  • پشتیبانی از چیدمان معکوس (درمورد این ویژگی در آموزش‌ جامع FlexBox بیشتر صحبت خواهیم کرد.)

شروع کدنویسی با FlexBox:

بعد از بررسی اینکه مزایای استفاده از FlexBox چیست، در این بخش قصد داریم تا یک منوی کناری و یک جعبه‌ی رنگ را طراحی کنیم. توجه داشته باشید که این مثالها تنها برای درک بهتر کارکرد FlexBox آورده شده‌اند و در آموزش جامع FlexBox به معرفی و نحوه‌ی استفاده از ویژگی‌های معمول FlexBox می‌پردازیم.

طراحی منوی کناری:

برای شروع، می‌خواهیم یک منوی کناری یا sidebar با استفاده از FlexBox به شکل زیر طراحی کنیم:

در گام اول ویژگی‌های صفحه و متن نوشته شده در صفحه را تعریف می‌کنیم.

* { margin: 0; padding: 0; } html, body { height: 100%; } body { font: 12px/1 'Montserrat', sans-serif; color: #333; background: #333; overflow-x: hidden; } h1 { margin: 120px 0 15px; font-size: 28px; font-weight: 400; }

در گام دوم ویژگی‌های مربوط به المان نگهدارنده را تعریف می‌کنیم:

.flex-container { display: flex; min-height: 100%; } .sidebar { position: absolute; width: 220px; }

در گام سوم، ویژگی‌های درون منوی کناری را طراحی می‌کنیم:

.content { flex: 1; padding: 30px; background: #eee; box-shadow: 0 0 5px black; } .content.wide { transform: translate3d(220px, 0, 0); } .nav li a { position: relative; display: block; padding: 15px 15px 15px 50px; font-size: 12px; color: #eee; border-bottom: 1px solid #222; }

در گام آخر، بدنه‌ی فرم را تعریف می‌کنیم. المان‌های موردنیاز ما عبارتند از: یک المان نگهدارنده که درون آن یک منوی کناری و یک صفحه نمایش قرار دارند. در درون منوی کناری سه گزینه برای تغییر صفحه داریم و در درون صفحه نمایش یک پیغام چاپ می‌کنیم.

<body> <div class='flex-container'> <div class='sidebar'> <div class='title'> Sidebar </div> <ul class='nav'> <li> <a>Dashboard</a> </li> <li> <a>Settings</a> </li> <li> <a>Logout</a> </li> </ul> </div> <div class='content wide'> <h1>Flexbox Off Canvas Menu</h1> </div> </div> </body>

و به همین سادگی توانستیم با FlexBox یک منوی کناری طراحی کنیم.

جمع بندی:

در این مطلب آموختیم که FlexBox چیست؟ و چه کاربردهایی دارد. برخلاف flexbox که روی طراحی تک بعدی تمرکز دارد، به کمک CSS grid می‌توان به خوبی لایه‌های دوبعدی را به صورت سطری و ستونی طراحی کرد. مرورگرهای مختلفی FlexBox را پشتیبانی کرده و نگرانی خاصی راجع به پشتیبانی مرورگرها از این ماژول وجود ندارد. در ادامه نیز در مورد مزایای استفاده از FlexBox صحبت کردیم. البته باید توجه داشت که برای یک طراحی خوب، استفاده از هر دو مدل CSS Grid و FlexBox ضروری است؛ چراکه هر دو امکانات جداگانه‌ای در اختیار طراح وب قرار می‌دهند. FlexBox در طراحی یک بعدی بسیار کارایی دارد و از طرف دیگر، CSS Grid در طراحی چندبعدی و برای تنظیم آیتم‌های سطرها و ستون‌ها ضروری است.

لازم به ذکر است که این موارد برای کسانی کارایی دارد که با طراحی وب، برنامه‌نویسی فرانت‌اند و به‌ویژه CSS آشنا باشند. همچنین اگر تجربه یا سوالی در کار با FlexBox دارید، با ما به اشتراک بگذارید.

cssflexbox
شاید از این پست‌ها خوشتان بیاید