ترکیب flexbox و grid در CSS
در طراحی رابطهای وب مدرن، استفاده همزمان از CSS Grid و Flexbox یک روش قدرتمند برای ایجاد لِاؤتهای منعطف و دقیق است. هرکدام از این دو ابزار نقاط قوت خاص خود را دارند: Grid برای ساختار دوبُعدی (ردیف و ستون) و Flex برای محور تکی و توزیع فضا بین آیتمها. در این مقاله به صورت عمیق و عملیاتی به ترکیب این دو میپردازیم، با مثالهای واقعی، نکات بهینهسازی و الگوهای معمول.
چرا باید Grid و Flex را ترکیب کنیم؟
- Grid برای طراحی اسکلت کلی صفحه (مثلاً هدرفوتر، سایدبار، محتوا) مناسب است.
- Flex برای چینش داخلی کامپوننتها (مثلاً آیتمهای ناوبری، کارتها، دکمهها) کاربردیتر است.
- با ترکیب میتوان کنترل دقیق روی هر دو بعد (عرض و ارتفاع) و همچنین تراز بندی محتوای داخلی را به دست آورد.
مقایسه کوتاه
| وظیفه | Grid | Flex |
|---|---|---|
| ساختار کلی چندستونی | عالی | مناسب نیست |
| تراز در یک محور | میتوان انجام داد اما پیچیده | عالی |
| چیدمان آیتمهای همرده | خوب | عالی |
مثال پایه: Grid برای لِیاوت، Flex برای ناوبری
/* HTML
<div class="page">
<header class="site-header">...</header>
<nav class="main-nav"><a>Home</a><a>About</a></nav>
<main class="content">...</main>
<aside class="sidebar">...</aside>
<footer>...</footer>
</div>
*/
/* CSS */.page {
display: grid;
grid-template-columns: 1fr 300px;
grid-template-rows: auto 1fr auto;
gap: 20px;
grid-template-areas:
"header header"
"content sidebar"
"footer footer";
min-height: 100vh;
}
.site-header { grid-area: header; }
.content { grid-area: content; }
.sidebar { grid-area: sidebar; }
footer { grid-area: footer; }
.main-nav {
display: flex;
gap: 12px;
align-items: center;
}
توضیح: در این مثال، کانتینر ریشه با Grid تعریف شده تا ستون محتوا و سایدبار مشخص شود. نوار ناوبری (.main-nav) داخل هدر یا هر بخش دیگری با Flex مدیریت میشود تا آیتمهای لینک به صورت افقی و با فاصله مرتب شوند. این الگو برای صفحات مرسوم وب بسیار کاربردی است.
الگوی واکنشگرایی: تغییر ترکیب در حالت موبایل
@media (max-width: 768px) {
.page {
grid-template-columns: 1fr;
grid-template-areas:
"header"
"content"
"sidebar"
"footer";
}
.main-nav {
flex-direction: column;
align-items: stretch;
}
}
توضیح: با مدیا کوئری، ساختار Grid به تک ستون تبدیل میشود و نوار ناوبری از حالت افقی به عمودی (ستونی) تغییر مییابد. این شیوه ترکیب Grid برای لِیاوت کلی و Flex برای تغییر چینش داخلی، تجربه کاربری واکنشپذیر را تضمین میکند.
نمونه پیشرفته: کارتهای با اندازههای متفاوت
.cards {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
gap: 16px;
}
.card {
display: flex;
flex-direction: column;
justify-content: space-between;
padding: 16px;
background: #fff;
border-radius: 8px;
}
توضیح: این الگو از Grid برای ایجاد شبکهای از کارتها با ستونهای واکنشگرا استفاده میکند. برای هر کارت، Flex به صورت ستونی قرار میگیرد تا عناصر داخل کارت (عنوان، متن، اکشنها) به طور طبیعی پر و تراز شوند. استفاده از auto-fill یا auto-fit همراه با minmax امکان تنظیم خودکار تعداد ستونها بر اساس فضا را میدهد.
نکات عملی و بهترین روشها
- برای لایهبندی صفحات بزرگ از Grid استفاده کنید و برای آیتمهای درون هر بلاک از Flex بهره ببرید.
- از gap در هر دو سیستم استفاده کنید؛ بهتر از مارجینهای دستی است و منظمتر عمل میکند.
- توجه به ترتیب DOM: Flex میتواند ترتیب بصری را تغییر دهد، اما برای دسترسی (a11y) بهتر است ترتیب منطقی در HTML حفظ شود.
- از
align-itemsوjustify-contentدر Flex برای تراز دقیق استفاده کنید و در Grid ازalign-contentوjustify-itemsبرای تنظیمات کلی. - پشتیبانی مرورگر: ویژگیهای اصلی Grid و Flex اکنون در مرورگرهای مدرن پشتیبانی میشوند، اما
subgridهنوز پشتیبانی کامل ندارد و باید با احتیاط استفاده شود.
چه زمانی نباید ترکیب کرد؟
- اگر نیاز تنها به یکبعدی چینش دارید، Flex سادهتر و خواناتر است.
- اگر ساختار فوقالعاده پیچیدهای دارید و فقط Grid کافی است، از اضافه کردن Flex غیرضروری خودداری کنید.
مشکلات رایج و رفع آنها
- مشکل تناقض ارتفاع: وقتی آیتمها در Grid ارتفاع متفاوت دارند، استفاده از Flex درون هر سلول برای تراز عمودی مشکل را حل میکند.
- فاصلهدهی با مارجین به جای gap: این کار باعث پیچیدگی در هماهنگی میشود؛ gap را ترجیح دهید.
مثال بهینهتر: استفاده از gap و minmax
.layout {
display: grid;
grid-template-columns: 1fr minmax(220px, 320px);
gap: 24px;
align-items: start;
}
.header-nav {
display: flex;
gap: 10px;
flex-wrap: wrap;
}
توضیح: این نسخه از Grid از minmax برای ستون سایدبار استفاده میکند تا بین حداقل و حداکثر منعطف باشد. align-items: start مانع کشیده شدن غیرضروری سلولها میشود و flex-wrap در ناوبری کمک میکند آیتمها در فضاهای کوچک به خط بعدی بروند.
خلاصه و الگوهای پیشنهادی
- الگوی معمول: Grid برای اسکلت صفحه + Flex برای آیتمهای داخلی (ناوبری، کارتها، دکمهها).
- برای پنوبها: Grid با گرید ایریا (named areas) و داخل هر منطقه از Flex جهت تراز محتوا استفاده کنید.
- برای کامپوننتهای تکرارشونده: یک کانتینر Grid + آیتمهای Flex برای کنترل داخلی بهترین کارایی و خوانایی را دارد.
با کمترین پیچیدگی میتوان از مزایای هر دو سیستم استفاده کرد. کلید موفقیت در طراحی، انتخاب ابزار مناسب برای هر سطح از لِیاوت و حفظ ساختار منطقی DOM است. ترکیب درست Grid و Flex منجر به رابطهای مرتب، واکنشپذیر و قابل نگهداری میشود.
آیا این مطلب برای شما مفید بود ؟




