بوت استرپ تم
بوت استرپ 4 را با متغیرهای جدید Sass داخلی ما برای ترجیحات سبک جهانی برای تغییر قالب و اجزای آسان سفارشی کنید.
مقدمه
در بوت استرپ 3، قالببندی عمدتاً توسط تغییر متغیرها در LESS، CSS سفارشی و یک صفحه سبک تم جداگانه که در dist
فایلهای خود گنجاندهایم هدایت میشد. با کمی تلاش، میتوان ظاهر بوت استرپ 3 را بدون دست زدن به فایلهای اصلی دوباره طراحی کرد. بوت استرپ 4 روشی آشنا، اما کمی متفاوت ارائه می دهد.
اکنون، قالببندی توسط متغیرهای Sass، نقشههای Sass و CSS سفارشی انجام میشود. صفحه سبک تم اختصاصی دیگری وجود ندارد. در عوض، میتوانید تم داخلی را برای افزودن گرادیان، سایهها و موارد دیگر فعال کنید.
ساس
از فایلهای Sass منبع ما برای استفاده از متغیرها، نقشهها، میکسها و موارد دیگر استفاده کنید. در ساختمان، دقت گرد کردن Sass را به ۶ افزایش دادهایم (به طور پیشفرض ۵ است) تا از مشکلات گرد کردن مرورگر جلوگیری کنیم.
ساختار فایل
در صورت امکان، از تغییر فایل های اصلی بوت استرپ خودداری کنید. برای Sass، این به معنای ایجاد شیوه نامه خود است که Bootstrap را وارد می کند تا بتوانید آن را تغییر دهید و گسترش دهید. با فرض اینکه از یک مدیریت بسته مانند npm استفاده می کنید، ساختار فایلی به شکل زیر خواهید داشت:
اگر فایلهای منبع ما را دانلود کردهاید و از یک مدیریت بسته استفاده نمیکنید، میخواهید به صورت دستی چیزی شبیه به آن ساختار را تنظیم کنید و فایلهای منبع بوت استرپ را از فایلهای منبع خود جدا نگه دارید.
واردات
در خود custom.scss
، فایلهای Sass منبع Bootstrap را وارد میکنید. شما دو گزینه دارید: همه Bootstrap را بگنجانید یا قطعات مورد نیاز خود را انتخاب کنید. ما دومی را تشویق میکنیم، اگرچه توجه داشته باشید که برخی الزامات و وابستگیها در اجزای ما وجود دارد. همچنین باید مقداری جاوا اسکریپت را برای افزونه های ما اضافه کنید.
با این تنظیمات، می توانید شروع به تغییر هر یک از متغیرها و نقشه های Sass در خود کنید custom.scss
. همچنین میتوانید در // Optional
صورت نیاز بخشهایی از Bootstrap را در زیر بخش اضافه کنید. پیشنهاد می کنیم از پشته کامل واردات از bootstrap.scss
فایل ما به عنوان نقطه شروع استفاده کنید.
پیش فرض های متغیر
هر متغیر Sass در Bootstrap 4 شامل !default
پرچمی است که به شما امکان می دهد بدون تغییر کد منبع Bootstrap، مقدار پیش فرض متغیر را در Sass خود لغو کنید. متغیرها را در صورت نیاز کپی و جایگذاری کنید، مقادیر آنها را تغییر دهید و !default
پرچم را حذف کنید. اگر متغیری قبلاً اختصاص داده شده باشد، با مقادیر پیشفرض در Bootstrap دوباره تخصیص داده نمیشود.
لیست کامل متغیرهای Bootstrap را در scss/_variables.scss
.
لغو متغیرها در همان فایل Sass می تواند قبل یا بعد از متغیرهای پیش فرض باشد. با این حال، هنگامی که در فایلهای Sass نادیده گرفته میشوید، بازنویسیهای شما باید قبل از وارد کردن فایلهای Sass Bootstrap انجام شود.
در اینجا یک مثال است که هنگام وارد کردن و کامپایل Bootstrap از طریق npm ، background-color
و color
for را تغییر میدهد:<body>
در صورت لزوم برای هر متغیری در Bootstrap، از جمله گزینه های جهانی زیر، این کار را تکرار کنید.
نقشه ها و حلقه ها
Bootstrap 4 شامل تعدادی نقشه Sass، جفتهای ارزش کلیدی است که تولید خانوادههای CSS مرتبط را آسانتر میکند. ما از نقشه های Sass برای رنگ ها، نقاط شکست شبکه و موارد دیگر استفاده می کنیم. درست مانند متغیرهای Sass، همه نقشههای Sass شامل !default
پرچم هستند و میتوان آنها را لغو و گسترش داد.
برخی از نقشه های Sass ما به طور پیش فرض در نقشه های خالی ادغام می شوند. این کار برای امکان گسترش آسان یک نقشه Sass انجام می شود، اما به قیمت حذف موارد از نقشه کمی دشوارتر است.
نقشه را اصلاح کنید
برای تغییر رنگ موجود در $theme-colors
نقشه، موارد زیر را به فایل Sass سفارشی خود اضافه کنید:
به نقشه اضافه کنید
برای افزودن یک رنگ جدید به $theme-colors
، کلید و مقدار جدید را اضافه کنید:
حذف از نقشه
برای حذف رنگ ها از $theme-colors
یا هر نقشه دیگری، از استفاده کنید map-remove
. توجه داشته باشید که باید آن را بین الزامات و گزینه های ما قرار دهید:
کلیدهای مورد نیاز
بوت استرپ وجود برخی از کلیدهای خاص را در نقشه های Sass فرض می کند که ما خودمان از آنها استفاده کرده و گسترش می دهیم. همانطور که نقشه های ارائه شده را سفارشی می کنید، ممکن است در هنگام استفاده از یک کلید Sass map خاص با خطاهایی مواجه شوید.
برای مثال، ما از کلیدهای، و از primary
برای success
پیوندها ، دکمهها و حالتهای فرم استفاده میکنیم. جایگزین کردن مقادیر این کلیدها نباید مشکلی ایجاد کند، اما حذف آنها ممکن است باعث ایجاد مشکلاتی در کامپایل Sass شود. در این موارد، شما باید کد Sass را تغییر دهید که از آن مقادیر استفاده می کند.danger
$theme-colors
کارکرد
بوت استرپ از چندین توابع Sass استفاده می کند، اما تنها یک زیرمجموعه برای تم کلی قابل استفاده است. ما سه تابع برای دریافت مقادیر از نقشه های رنگی قرار داده ایم:
اینها به شما این امکان را می دهند که یک رنگ را از نقشه Sass انتخاب کنید، دقیقاً مانند نحوه استفاده از یک متغیر رنگ از نسخه 3.
ما همچنین عملکرد دیگری برای دریافت سطح خاصی از رنگ از $theme-colors
نقشه داریم. مقادیر سطح منفی رنگ را روشن می کند، در حالی که سطوح بالاتر تیره می شود.
در عمل، شما باید تابع را فراخوانی و در دو پارامتر ارسال کنید: نام رنگ از $theme-colors
(به عنوان مثال، اولیه یا خطر) و یک سطح عددی.
توابع اضافی را می توان در آینده اضافه کرد یا Sass سفارشی شما برای ایجاد توابع سطح برای نقشه های Sass اضافی، یا حتی اگر می خواهید پرمخاطب تر باشید، یک توابع عمومی اضافه کنید.
تضاد رنگ
یکی از عملکردهای اضافی که در Bootstrap قرار می دهیم، تابع کنتراست رنگ است color-yiq
. از فضای رنگی YIQ برای برگرداندن خودکار رنگ کنتراست روشن ( #fff
) یا تیره ( #111
) بر اساس رنگ پایه مشخص شده استفاده می کند. این تابع به ویژه برای میکسها یا حلقههایی که در آن چندین کلاس تولید میکنید مفید است.
به عنوان مثال، برای تولید نمونه های رنگی از $theme-colors
نقشه ما:
همچنین می تواند برای نیازهای یکباره کنتراست استفاده شود:
شما همچنین می توانید یک رنگ پایه را با توابع نقشه رنگی ما مشخص کنید:
گزینه های Sass
بوت استرپ 4 را با فایل متغیرهای سفارشی داخلی ما سفارشی کنید و به راحتی تنظیمات CSS جهانی را با $enable-*
متغیرهای جدید Sass تغییر دهید. مقدار یک متغیر را نادیده بگیرید و در npm run test
صورت نیاز دوباره کامپایل کنید.
می توانید این متغیرها را برای گزینه های کلیدی جهانی در scss/_variables.scss
فایل بوت استرپ پیدا کرده و سفارشی کنید.
متغیر | ارزش های | شرح |
---|---|---|
$spacer |
1rem (پیشفرض)، یا هر مقدار > 0 |
مقدار پیشفرض فاصلهگذار را برای تولید برنامهای ابزارهای فاصلهگذار ما مشخص میکند. |
$enable-rounded |
true (پیش فرض) یاfalse |
border-radius استایل های از پیش تعریف شده را روی اجزای مختلف فعال می کند. |
$enable-shadows |
true یا false (پیش فرض) |
box-shadow استایل های از پیش تعریف شده را روی اجزای مختلف فعال می کند. |
$enable-gradients |
true یا false (پیش فرض) |
گرادیان های از پیش تعریف شده را از طریق background-image استایل ها روی اجزای مختلف فعال می کند. |
$enable-transitions |
true (پیش فرض) یاfalse |
s های از پیش تعریف شده transition را روی اجزای مختلف فعال می کند. |
$enable-prefers-reduced-motion-media-query |
true (پیش فرض) یاfalse |
prefers-reduced-motion درخواست رسانه را فعال میکند ، که انیمیشنها/انتقالهای خاصی را بر اساس تنظیمات برگزیده مرورگر/سیستم عامل کاربران سرکوب میکند. |
$enable-hover-media-query |
true یا false (پیش فرض) |
منسوخ |
$enable-grid-classes |
true (پیش فرض) یاfalse |
تولید کلاسهای CSS را برای سیستم شبکه فعال میکند (به عنوان مثال،،،، و .container غیره )..row .col-md-1 |
$enable-caret |
true (پیش فرض) یاfalse |
کارت شبه عنصر را فعال می .dropdown-toggle کند. |
$enable-print-styles |
true (پیش فرض) یاfalse |
سبک ها را برای بهینه سازی چاپ فعال می کند. |
$enable-validation-icons |
true (پیش فرض) یاfalse |
background-image نمادها را در ورودی های متنی و برخی از فرم های سفارشی برای حالت های اعتبار سنجی فعال می کند. |
رنگ
بسیاری از اجزا و ابزارهای مختلف Bootstrap از طریق یک سری رنگ تعریف شده در نقشه Sass ساخته می شوند. این نقشه را می توان در Sass حلقه کرد تا به سرعت مجموعه ای از قوانین را تولید کند.
همه رنگ ها
تمام رنگ های موجود در Bootstrap 4، به عنوان متغیرهای Sass و نقشه Sass در scss/_variables.scss
فایل موجود هستند. این در نسخههای کوچک بعدی برای افزودن سایههای اضافی، بسیار شبیه پالت خاکستری که قبلاً اضافه کردهایم، گسترش خواهد یافت.
در اینجا نحوه استفاده از آنها در Sass آمده است:
کلاس های کاربردی رنگ نیز برای تنظیم color
و background-color
.
در آینده، همانطور که با رنگهای خاکستری زیر انجام دادیم، نقشهها و متغیرهای Sass را برای سایههای هر رنگ ارائه خواهیم کرد.
رنگ های تم
ما از زیرمجموعهای از همه رنگها برای ایجاد یک پالت رنگی کوچکتر برای تولید طرحهای رنگی استفاده میکنیم، همچنین به عنوان متغیرهای Sass و نقشه Sass در scss/_variables.scss
فایل Bootstraps موجود است.
خاکستری ها
مجموعه گسترده ای از متغیرهای خاکستری و نقشه Sass scss/_variables.scss
برای سایه های خاکستری ثابت در پروژه شما. توجه داشته باشید که اینها "خاکستری های سرد" هستند که به جای خاکستری های خنثی به رنگ آبی ظریف تمایل دارند.
در داخل scss/_variables.scss
، متغیرهای رنگ Bootstrap و نقشه Sass را خواهید یافت. در اینجا یک نمونه از $colors
نقشه Sass آمده است:
مقادیر را در نقشه اضافه، حذف یا تغییر دهید تا نحوه استفاده از آنها در بسیاری از مؤلفههای دیگر بهروزرسانی شود. متأسفانه در حال حاضر، همه مؤلفه ها از این نقشه Sass استفاده نمی کنند. به روز رسانی های آینده در تلاش برای بهبود این موضوع خواهد بود. تا آن زمان، برای استفاده از ${color}
متغیرها و این نقشه Sass برنامه ریزی کنید.
اجزاء
بسیاری از مؤلفهها و ابزارهای کمکی Bootstrap با @each
حلقههایی ساخته شدهاند که روی نقشه Sass تکرار میشوند. این به ویژه برای تولید انواع یک جزء توسط ما $theme-colors
و ایجاد انواع پاسخگو برای هر نقطه شکست مفید است. همانطور که این نقشه های Sass را سفارشی می کنید و دوباره کامپایل می کنید، به طور خودکار تغییرات خود را در این حلقه ها منعکس می کنید.
اصلاح کننده ها
بسیاری از اجزای بوت استرپ با رویکرد کلاس اصلاح کننده پایه ساخته شده اند. این بدان معناست که بخش عمده ای از یک ظاهر طراحی شده در یک کلاس پایه (مثلاً .btn
) قرار می گیرد در حالی که تغییرات سبک به کلاس های اصلاح کننده (مثلاً، .btn-danger
) محدود می شود. این کلاسهای اصلاحکننده از $theme-colors
روی نقشه ساخته شدهاند تا تعداد و نام کلاسهای اصلاحکننده ما را سفارشی کنند.
در اینجا دو مثال از نحوه حلقه زدن $theme-colors
روی نقشه برای تولید اصلاح کنندههای .alert
کامپوننت و همه .bg-*
ابزارهای پسزمینه ما آورده شده است.
پاسخگو
این حلقههای Sass به نقشههای رنگی نیز محدود نمیشوند. شما همچنین می توانید تغییرات پاسخگو از اجزا یا ابزارهای خود را ایجاد کنید. به عنوان مثال ابزارهای تراز متن پاسخگو ما را در نظر بگیرید که در آن یک @each
حلقه برای $grid-breakpoints
نقشه Sass را با یک جستجوی رسانه ای ترکیب می کنیم.
اگر نیاز به تغییر خود $grid-breakpoints
داشته باشید، تغییرات شما برای همه حلقههایی که روی نقشه تکرار میشوند اعمال میشود.
متغیرهای CSS
Bootstrap 4 شامل حدود دوجین ویژگی (متغیر) سفارشی CSS در CSS کامپایل شده خود است. اینها هنگام کار در Inspector مرورگر، جعبه ماسه کد یا نمونهسازی عمومی، دسترسی آسان به مقادیر رایج مانند رنگهای موضوع، نقاط شکست و پشتههای فونت اصلی ما را فراهم میکنند.
متغیرهای موجود
در اینجا متغیرهایی هستند که ما اضافه می کنیم (توجه داشته باشید که :root
لازم است). آنها در _root.scss
پرونده ما قرار دارند.
مثال ها
متغیرهای CSS انعطاف پذیری مشابهی با متغیرهای Sass ارائه می دهند، اما بدون نیاز به کامپایل قبل از ارائه به مرورگر. به عنوان مثال، در اینجا ما فونت و سبک های پیوند صفحه خود را با متغیرهای CSS بازنشانی می کنیم.
متغیرهای نقطه شکست
در حالی که ما در ابتدا نقاط شکست را در متغیرهای CSS خود گنجانده بودیم (به عنوان مثال، --breakpoint-md
)، اینها در پرسوجوهای رسانه پشتیبانی نمیشوند ، اما همچنان میتوانند در مجموعه قوانین در جستارهای رسانه استفاده شوند. این متغیرهای نقطه شکست در CSS کامپایل شده برای سازگاری با عقب مانده باقی می مانند زیرا می توانند توسط جاوا اسکریپت مورد استفاده قرار گیرند. در مشخصات بیشتر بیاموزید
در اینجا نمونه ای از مواردی که پشتیبانی نمی شود آورده شده است:
و در اینجا نمونه ای از آنچه پشتیبانی می شود آورده شده است: