ده طرح بندی مدرن در یک خط CSS

طرح‌بندی‌های مدرن CSS به توسعه‌دهندگان این امکان را می‌دهد که قوانین سبک واقعاً معنی‌دار و قوی را تنها با چند ضربه کلید بنویسند. گفتگوی بالا و این پست بعدی 10 خط قدرتمند CSS را بررسی می کند که کارهای سنگین را انجام می دهند.

برای دنبال کردن یا بازی با این دموها به تنهایی، جاسازی Glitch در بالا را بررسی کنید یا از 1linelayouts.glitch.me دیدن کنید.

01. Super Centered: place-items: center

برای اولین طرح "تک خطی"، بیایید بزرگترین رمز و راز در تمام سرزمین CSS را حل کنیم: متمرکز کردن چیزها. می‌خواهم بدانید که با place-items: center .

ابتدا grid به عنوان روش display مشخص کنید و سپس place-items: center همان عنصر بنویسید. place-items کوتاه نویسی برای تنظیم هم align-items و justify-items به طور همزمان است. با تنظیم آن در center ، هم align-items و هم justify-items در center قرار می گیرند.

.parent {
  display: grid;
  place-items: center;
}

این امکان را فراهم می کند تا محتوا بدون توجه به اندازه ذاتی، کاملاً در مرکز اصلی قرار گیرد.

02. Pancake Deconstructed: flex: <grow> <shrink> <baseWidth>

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

با استفاده از Flexbox برای این افکت، برای تنظیم محل قرارگیری این عناصر در هنگام تغییر اندازه صفحه، نیازی به درخواست رسانه ندارید.

مخفف flex مخفف: flex: <flex-grow> <flex-shrink> <flex-basis> .

به همین دلیل، اگر می‌خواهید جعبه‌های شما به اندازه <flex-basis> خود پر شوند، در اندازه‌های کوچک‌تر کوچک شوند، اما برای پر کردن فضای اضافی کشیده نشوند، بنویسید: flex: 0 1 <flex-basis> . در این مورد، <flex-basis> شما 150px است، بنابراین به نظر می رسد:

.parent {
  display: flex;
}

.child {
  flex: 0 1 150px;
}

اگر می‌خواهید که جعبه‌ها در خط بعدی کشیده شوند و فضا را پر کنند، <flex-grow> را روی 1 تنظیم کنید، به این ترتیب به نظر می‌رسد:

.parent {
  display: flex;
}

.child {
  flex: 1 1 150px;
}

اکنون، با افزایش یا کاهش اندازه صفحه، این موارد انعطاف پذیر هم کوچک می شوند و هم رشد می کنند.

03. نوار کناری می گوید: grid-template-columns: minmax(<min>, <max>) …)

این نسخه ی نمایشی از تابع minmax برای طرح بندی شبکه بهره می برد. کاری که ما در اینجا انجام می‌دهیم این است که حداقل اندازه نوار کناری را 150px تعیین می‌کنیم، اما در صفحه‌های بزرگ‌تر، اجازه می‌دهیم تا 25% افزایش یابد. نوار کناری همیشه 25% از فضای افقی والد خود را اشغال می کند تا زمانی که این 25% کوچکتر از 150px شود.

این را به عنوان مقدار grid-template-columns با مقدار زیر اضافه کنید: minmax(150px, 25%) 1fr . آیتم در ستون اول (نوار کناری در این مورد) minmax 150px در 25% دریافت می کند، و مورد دوم (بخش main در اینجا) بقیه فضا را به عنوان یک تراک 1fr اشغال می کند.

.parent {
  display: grid;
  grid-template-columns: minmax(150px, 25%) 1fr;
}

04. پشته پنکیک: grid-template-rows: auto 1fr auto

بر خلاف Deconstructed Pancake، این مثال وقتی اندازه صفحه نمایش تغییر می کند، فرزندان خود را نمی پوشاند. این طرح‌بندی که معمولاً به عنوان پاورقی چسبنده نامیده می‌شود، اغلب برای وب‌سایت‌ها و برنامه‌ها، در میان برنامه‌های تلفن همراه (پانویس معمولاً یک نوار ابزار است) و وب‌سایت‌ها (برنامه‌های یک صفحه اغلب از این طرح‌بندی کلی استفاده می‌کنند) استفاده می‌شود.

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

برای چسباندن پاورقی به پایین، اضافه کنید:

.parent {
  display: grid;
  grid-template-rows: auto 1fr auto;
}

این امر محتوای سرصفحه و پاورقی را طوری تنظیم می‌کند که به‌طور خودکار اندازه فرزندان خود را بگیرد، و فضای باقی‌مانده ( 1fr ) را در ناحیه اصلی اعمال می‌کند، در حالی که ردیف با اندازه auto اندازه حداقل محتوای فرزندان خود را می‌گیرد. اندازه افزایش می یابد، خود ردیف رشد می کند تا تنظیم شود.

05. چیدمان جام مقدس کلاسیک: grid-template: auto 1fr auto / auto 1fr auto

برای این طرح جام مقدس کلاسیک، سرصفحه، پاورقی، نوار کناری سمت چپ، نوار کناری سمت راست و محتوای اصلی وجود دارد. این شبیه به طرح قبلی است، اما اکنون با نوارهای کناری!

برای نوشتن کل این شبکه با استفاده از یک خط کد، از ویژگی grid-template استفاده کنید. این به شما امکان می دهد تا ردیف ها و ستون ها را همزمان تنظیم کنید.

جفت ویژگی و مقدار عبارتند از: grid-template: auto 1fr auto / auto 1fr auto . اسلش بین لیست های اول و دوم جدا شده با فاصله، فاصله بین سطرها و ستون ها است.

.parent {
  display: grid;
  grid-template: auto 1fr auto / auto 1fr auto;
}

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

06. 12-Span Grid: grid-template-columns: repeat(12, 1fr)

بعد کلاسیک دیگری داریم: شبکه 12 دهانه. شما می توانید به سرعت گریدها را در CSS با تابع repeat() بنویسید. استفاده از: repeat(12, 1fr); برای ستون های الگوی شبکه ای 12 ستون هر یک از 1fr را به شما می دهد.

.parent {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
}

.child-span-12 {
  grid-column: 1 / 13;
}

اکنون شما یک شبکه مسیر 12 ستونی دارید، ما می توانیم فرزندان خود را روی شبکه قرار دهیم. یکی از راه های انجام این کار قرار دادن آنها با استفاده از خطوط شبکه است. به عنوان مثال، grid-column: 1 / 13 از اولین خط تا آخرین (سیزدهم) و 12 ستون را در بر می گیرد. grid-column: 1 / 5; چهار مورد اول را در بر می گیرد.

روش دیگر برای نوشتن این، استفاده از کلمه کلیدی span است. با span ، خط شروع و سپس تعداد ستون هایی را که از آن نقطه شروع باید باز شوند را تعیین می کنید. در این حالت، grid-column: 1 / span 12 معادل grid-column: 1 / 13 و grid-column: 2 / span 6 معادل grid-column: 2 / 8 خواهد بود.

.child-span-12 {
  grid-column: 1 / span 12;
}

07. RAM (تکرار، خودکار، MinMax): grid-template-columns(auto-fit, minmax(<base>, 1fr))

برای این مثال هفتم، برخی از مفاهیمی را که قبلاً در مورد آنها آموخته‌اید ترکیب کنید تا یک طرح‌بندی پاسخگو با کودکانی که به طور خودکار قرار می‌گیرند و انعطاف‌پذیر ایجاد کنید. خیلی مرتب عبارات کلیدی که در اینجا باید به خاطر بسپارید عبارتند از repeat , auto-(fit|fill) , و minmax()' که با مخفف RAM به خاطر می آورید.

با هم، به نظر می رسد:

.parent {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

شما دوباره از تکرار استفاده می کنید، اما این بار، به جای یک مقدار عددی صریح، از کلمه کلیدی auto-fit استفاده می کنید. این امکان قرار دادن خودکار این عناصر کودک را فراهم می کند. این کودکان همچنین دارای حداقل مقدار پایه 150px با حداکثر مقدار 1fr هستند، به این معنی که در صفحه‌های کوچک‌تر، عرض کامل 1fr را می‌گیرند، و با رسیدن به عرض هر کدام به 150px ، شروع به جریان شدن روی همان خط می‌کنند.

با auto-fit ، جعبه ها به دلیل اینکه اندازه افقی آنها از 150 پیکسل فراتر می رود کشیده می شوند تا کل فضای باقی مانده را پر کنند. با این حال، اگر این مورد را به auto-fill تغییر دهید، زمانی که اندازه پایه آنها در تابع minmax بیشتر شود، کشیده نمی‌شوند:

.parent {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

08. Line Up: justify-content: space-between

برای چیدمان بعدی، نکته اصلی که باید در اینجا نشان داده شود justify-content: space-between است که اولین و آخرین عنصر فرزند را در لبه‌های جعبه مرزی خود قرار می‌دهد و فضای باقی‌مانده به طور مساوی بین عناصر توزیع می‌شود. برای این کارت‌ها، آن‌ها در حالت نمایش Flexbox قرار می‌گیرند و جهت آن با استفاده از flex-direction: column روی ستون تنظیم می‌شود.

این عنوان، توضیحات و بلوک تصویر را در یک ستون عمودی در داخل کارت والد قرار می دهد. سپس، اعمال justify-content: space-between اولین (عنوان) و آخرین (بلوک تصویر) عناصر را به لبه‌های فلکس باکس متصل می‌کند و متن توصیفی بین آن‌ها با فاصله‌های مساوی در هر نقطه پایانی قرار می‌گیرد.

.parent {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

09. بستن سبک من: clamp(<min>, <actual>, <max>)

اینجا جایی است که ما به تکنیک‌هایی با پشتیبانی کمتر از مرورگر می‌پردازیم، اما پیامدهای واقعاً هیجان‌انگیزی برای طرح‌بندی‌ها و طراحی UI پاسخگو داریم. در این نسخه نمایشی، عرض را با استفاده از گیره تنظیم می کنید: width: clamp(<min>, <actual>, <max>) .

این یک حداقل و حداکثر اندازه مطلق و یک اندازه واقعی را تعیین می کند. با مقادیر، می تواند شبیه به این باشد:

.parent {
  width: clamp(23ch, 60%, 46ch);
}

حداقل اندازه در اینجا 23ch یا 23 واحد کاراکتر و حداکثر اندازه 46ch ، 46 کاراکتر است. واحدهای عرض کاراکتر بر اساس اندازه قلم عنصر (به ویژه عرض علامت 0 ) است. اندازه "واقعی" 50٪ است که 50٪ از عرض اصلی این عنصر را نشان می دهد.

کاری که تابع clamp() در اینجا انجام می دهد این است که این عنصر را قادر می سازد تا عرض 50% را حفظ کند تا زمانی که 50% یا بزرگتر از 46ch (در ویوپورت های عریض تر)، یا کوچکتر از 23ch (در نمای کوچکتر) شود. می بینید که با کشش و کوچک شدن اندازه والد، عرض این کارت به حداکثر نقطه گیره شده افزایش می یابد و به حداقل گیره آن کاهش می یابد. سپس در وسط والد باقی می‌ماند زیرا ویژگی‌های اضافی را برای وسط آن اعمال کرده‌ایم. این طرح‌بندی‌های خواناتر را امکان‌پذیر می‌کند، زیرا متن خیلی عریض (بالاتر از 46ch ) یا خیلی فشرده و باریک (کمتر از 23ch ) نخواهد بود.

این نیز یک راه عالی برای پیاده سازی تایپوگرافی واکنش گرا است. به عنوان مثال، می توانید بنویسید: font-size: clamp(1.5rem, 20vw, 3rem) . در این حالت، اندازه قلم یک عنوان همیشه بین 1.5rem و 3rem ثابت می ماند، اما بر اساس مقدار واقعی 20vw رشد و کوچک می شود تا با عرض درگاه دید مطابقت داشته باشد.

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

10. Respect for Aspect: aspect-ratio: <width> / <height>

و در نهایت، این آخرین ابزار چیدمان، آزمایشی ترین ابزار از این دسته است. اخیراً در Chromium 84 به Chrome Canary معرفی شد و تلاش فعالی از طرف فایرفاکس برای پیاده سازی آن انجام شده است، اما در حال حاضر در هیچ نسخه مرورگر پایداری وجود ندارد.

با این حال، من می خواهم به این موضوع اشاره کنم، زیرا مشکلی است که اغلب دیده می شود. و این فقط حفظ نسبت تصویر یک تصویر است.

با ویژگی aspect-ratio ، همانطور که اندازه کارت را تغییر می‌دهم، بلوک بصری سبز این نسبت تصویر 16 در 9 را حفظ می‌کند. ما به نسبت تصویر با aspect-ratio: 16 / 9 احترام می گذاریم.

.video {
  aspect-ratio: 16 / 9;
}

برای حفظ نسبت تصویر 16 x 9 بدون این ویژگی، باید از یک padding-top hack استفاده کنید و به آن padding 56.25% بدهید تا نسبت بالا به عرض را تنظیم کنید. برای جلوگیری از هک شدن و نیاز به محاسبه درصد، به زودی یک خاصیت برای این کار خواهیم داشت. شما می توانید مربعی با نسبت 1 / 1 ، نسبت 2 به 1 با 2 / 1 و در واقع هر چیزی که برای مقیاس بندی این تصویر با نسبت اندازه تنظیم شده نیاز دارید بسازید.

.square {
  aspect-ratio: 1 / 1;
}

در حالی که این ویژگی هنوز در دسترس است، دانستن آن خوب است زیرا بسیاری از اختلافات توسعه دهندگان را که من بارها با آن مواجه شده ام، حل می کند، به خصوص در مورد ویدیو و آی فریم.

نتیجه گیری

از شما برای پیگیری این سفر از طریق 10 خط قدرتمند CSS سپاسگزاریم. برای کسب اطلاعات بیشتر، ویدیوی کامل را تماشا کنید و خودتان دموها را امتحان کنید.