مهاجرت به نسخه 4
Bootstrap 4 بازنویسی اصلی کل پروژه است. قابل توجه ترین تغییرات در زیر خلاصه شده است و به دنبال آن تغییرات خاص تر در اجزای مربوطه آمده است.
تغییرات پایدار
با انتقال از نسخه بتا 3 به نسخه پایدار v4.x، هیچ تغییری وجود ندارد، اما تغییرات قابل توجهی وجود دارد.
چاپ
-
تعمیر ابزارهای چاپ شکسته قبلاً، استفاده از یک
.d-print-*
کلاس به طور غیرمنتظره ای هر.d-*
کلاس دیگری را رد می کرد. اکنون، آنها با سایر ابزارهای نمایشگر ما مطابقت دارند و فقط برای آن رسانه اعمال می شوند (@media print
). -
ابزارهای نمایش چاپ موجود را برای مطابقت با سایر ابزارها گسترش داد. نسخه بتا 3 و بالاتر فقط
block
,inline-block
,inline
, وnone
. Stable v4 اضافهflex
شدinline-flex
،،،،،table
وtable-row
.table-cell
-
رندر پیشنمایش چاپ در مرورگرها با سبکهای چاپ جدید که مشخص میکنند، ثابت
@page
size
شد.
تغییرات بتا 3
در حالی که بتا 2 شاهد بخش عمده ای از تغییرات اساسی ما در مرحله بتا بود، اما ما هنوز چند مورد را داریم که باید در نسخه بتا 3 به آنها پرداخته شود. اگر از نسخه بتا 2 یا هر نسخه قدیمی بوت استرپ به نسخه بتا 3 بروزرسانی می کنید، این تغییرات اعمال می شود.
متفرقه
$thumbnail-transition
متغیر استفاده نشده را حذف کرد . ما در حال انتقال چیزی نبودیم، بنابراین فقط کد اضافی بود.- بسته npm دیگر شامل هیچ فایلی غیر از فایل های منبع و dist ما نمی شود. اگر به آنها تکیه میکردید و اسکریپتهای ما را از طریق
node_modules
پوشه اجرا میکردید، باید گردش کار خود را تطبیق دهید.
تشکیل می دهد
-
هر دو چک باکس سفارشی و پیش فرض و رادیو را بازنویسی کرد. اکنون، هر دو دارای ساختار HTML منطبق (خارجی
<div>
با خواهر و برادر<input>
و<label>
) و سبکهای چیدمان یکسان (پیشفرض پشتهای، درون خط با کلاس اصلاحکننده) هستند. این به ما امکان می دهد برچسب را بر اساس وضعیت ورودی استایل دهیم، پشتیبانی ازdisabled
ویژگی را ساده می کند (که قبلاً به یک کلاس والد نیاز داشت) و اعتبارسنجی فرم خود را بهتر پشتیبانی می کند.به عنوان بخشی از این، ما CSS را برای مدیریت چندین
background-image
s در چک باکسهای فرم سفارشی و رادیوها تغییر دادهایم. قبلاً،.custom-control-indicator
عنصر حذف شده دارای رنگ پسزمینه، شیب و نماد SVG بود. سفارشی کردن گرادیان پسزمینه به معنای جایگزینی همه آنها هر بار که لازم بود فقط یکی را تغییر دهید. در حال حاضر، ما.custom-control-label::before
برای fill و گرادیان و.custom-control-label::after
کنترل آیکون داریم.برای ایجاد یک بررسی سفارشی به صورت درون خطی، اضافه کنید
.custom-control-inline
. -
انتخابگر به روز شده برای گروه های دکمه های مبتنی بر ورودی. به جای
[data-toggle="buttons"] { }
برای سبک و رفتار، از ویژگی فقط برای رفتارهای JS استفاده میکنیم و برای استایلسازی به کلاسdata
جدیدی تکیه میکنیم..btn-group-toggle
-
حذف
.col-form-legend
به نفع کمی بهبود یافته.col-form-label
است. به این ترتیب.col-form-label-sm
و.col-form-label-lg
می توان به<legend>
راحتی بر روی عناصر استفاده کرد. -
ورودی های فایل سفارشی تغییری در
$custom-file-text
متغیر Sass خود دریافت کردند. این دیگر یک نقشه Sass تودرتو نیست و اکنون فقط یک رشته را فعال می کند -Browse
دکمه زیرا اکنون تنها شبه عنصر تولید شده از Sass ما است. متن اکنونChoose file
از.custom-file-label
.
گروه های ورودی
-
افزونههای گروه ورودی در حال حاضر مختص قرارگیری آنها نسبت به یک ورودی هستند. ما دو کلاس جدید را رها کردیم
.input-group-addon
و . اکنون باید صراحتاً از یک ضمیمه یا یک prepend استفاده کنید که بیشتر CSS ما را ساده می کند. در یک ضمیمه یا پیشبند، دکمههای خود را همانطور که در هر جای دیگری وجود دارند قرار دهید، اما متن را در آن قرار دهید ..input-group-btn
.input-group-prepend
.input-group-append
.input-group-text
-
اکنون سبک های اعتبار سنجی مانند ورودی های متعدد پشتیبانی می شوند (اگرچه شما فقط می توانید یک ورودی را در هر گروه تأیید کنید).
-
کلاسهای اندازهگیری باید بر روی والد باشد
.input-group
و نه عناصر فرم فردی.
بتا 2 تغییر می کند
در حالی که در نسخه بتا هستیم، هدف ما این است که هیچ تغییری نداشته باشیم. با این حال، همیشه همه چیز طبق برنامه پیش نمی رود. در زیر تغییرات اساسی وجود دارد که باید هنگام انتقال از بتا 1 به بتا 2 در نظر داشت.
شکستن
$badge-color
متغیر حذف شده و استفاده از آن در.badge
. ما از یک تابع کنتراست رنگ برای انتخاب یکcolor
بر اساس استفاده می کنیمbackground-color
، بنابراین متغیر غیر ضروری است.- برای جلوگیری از شکستن تضاد با فیلتر اصلی CSS، نام
grayscale()
تابع به تغییر نام داده شد.gray()
grayscale
- تغییر نام
.table-inverse
،.thead-inverse
و.thead-default
به.*-dark
و.*-light
، مطابق با طرح های رنگی ما که در جاهای دیگر استفاده می شود. - جداول پاسخگو اکنون کلاس هایی را برای هر نقطه شکست شبکه تولید می کنند. این از نسخه بتا 1 جدا می شود زیرا نسخه ای که
.table-responsive
استفاده می کنید بیشتر شبیه به.table-responsive-md
. اکنون می توانید.table-responsive
یا.table-responsive-{sm,md,lg,xl}
در صورت نیاز استفاده کنید. - پشتیبانی Bower بهعنوان مدیر بسته برای گزینههای جایگزین (به عنوان مثال، Yarn یا npm) منسوخ شده است. برای جزئیات بیشتر به bower/bower#2298 مراجعه کنید.
- Bootstrap همچنان به jQuery 1.9.1 یا بالاتر نیاز دارد، اما به شما توصیه می شود از نسخه 3.x استفاده کنید زیرا مرورگرهای پشتیبانی شده v3.x همان مرورگرهایی هستند که Bootstrap پشتیبانی می کند به علاوه v3.x دارای برخی اصلاحات امنیتی است.
- کلاس استفاده نشده حذف شد
.form-control-label
. اگر از این کلاس استفاده کردید، این کلاس تکراری بود.col-form-label
که به صورت عمودی a<label>
را با ورودی مرتبط آن در طرحبندیهای فرم افقی وسط میکرد. color-yiq
از یک mixin که دارای ویژگی است به تابعی که مقداری را برمی گرداند تغییرcolor
داد و به شما امکان می دهد از آن برای هر ویژگی CSS استفاده کنید. به عنوان مثال، به جایcolor-yiq(#000)
، مینویسیدcolor: color-yiq(#000);
.
نکات برجسته
- استفاده جدید
pointer-events
در مدال ها معرفی شد. قسمت بیرونی.modal-dialog
از میان رویدادها باpointer-events: none
مدیریت کلیک سفارشی عبور می کند (این امکان را می دهد که فقط برای هر کلیکی به آن گوش دهید )، و سپس با آن به طور واقعی با.modal-backdrop
آن مقابله می کند ..modal-content
pointer-events: auto
خلاصه
در اینجا آیتم های بلیط بزرگی وجود دارد که می خواهید هنگام انتقال از نسخه 3 به نسخه 4 از آنها آگاه باشید.
پشتیبانی از مرورگر
- پشتیبانی از IE8، IE9 و iOS 6 قطع شد. نسخه 4 اکنون فقط IE10+ و iOS 7+ است. برای سایت هایی که به هر یک از آنها نیاز دارند، از v3 استفاده کنید.
- پشتیبانی رسمی برای مرورگر Android v5.0 Lollipop و WebView اضافه شد. نسخه های قبلی مرورگر Android و WebView فقط به صورت غیر رسمی پشتیبانی می شوند.
تغییرات جهانی
- Flexbox به طور پیش فرض فعال است. به طور کلی این به معنای دور شدن از شناورها و بیشتر در اجزای ما است.
- برای فایلهای CSS منبع ما، از Less به Sass تغییر وضعیت داد.
- بهعنوان واحد CSS اصلی ما، از
px
بهrem
بهعنوان واحد CSS اصلی ما جابهجا شد، اگرچه پیکسلها همچنان برای درخواستهای رسانه و رفتار شبکه استفاده میشوند، زیرا درگاههای نمای دستگاه تحت تأثیر اندازه نوع قرار نمیگیرند. - اندازه قلم جهانی از
14px
به افزایش یافت16px
. - سطوح شبکه را برای افزودن گزینه پنجم (آدرس کردن دستگاههای کوچکتر در
576px
پایین و پایین) اصلاح کرد و-xs
infix را از آن کلاسها حذف کرد. مثال:.col-6.col-sm-4.col-md-3
. - موضوع اختیاری جداگانه را با گزینه های قابل تنظیم از طریق متغیرهای SCSS (به عنوان مثال،
$enable-gradients: true
) جایگزین کرد. - سیستم ساخت برای استفاده از یک سری اسکریپت های npm به جای Grunt بازنگری شد. برای
package.json
همه اسکریپت ها یا پروژه readme ما برای نیازهای توسعه محلی را ببینید. - استفاده غیر پاسخگو از Bootstrap دیگر پشتیبانی نمی شود.
- Customizer آنلاین را به نفع اسناد راه اندازی گسترده تر و ساخت های سفارشی حذف کرد.
- دهها کلاس کاربردی جدید برای جفتهای ویژگی-مقدار متداول CSS و میانبرهای فاصله حاشیه/بالا اضافه شده است.
سیستم شبکه ای
- به flexbox منتقل شد.
- پشتیبانی از flexbox در میکس های شبکه و کلاس های از پیش تعریف شده اضافه شده است.
- به عنوان بخشی از flexbox، شامل پشتیبانی از کلاس های تراز عمودی و افقی است.
- نام کلاس های شبکه و یک ردیف شبکه جدید به روز شده است.
sm
یک لایه شبکه جدید در زیر768px
برای کنترل دانه ای بیشتر اضافه شده است. ما اکنون داریمxs
،،،،، و . این همچنین به این معنی است که هر سطح یک سطح افزایش یافته است (بنابراین در v3 اکنون در v4 است).sm
md
lg
xl
.col-md-6
.col-lg-6
xs
کلاسهای گرید به گونهای اصلاح شدهاند که نیازی به پسوند برای نشان دادن دقیقتر این نیست که آنها شروع به اعمال سبکها درmin-width: 0
و نه یک مقدار پیکسل تعیینشده میکنند. به جای اینکه.col-xs-6
الان هست.col-6
. همه سطوح شبکه دیگر نیاز به infix دارند (به عنوان مثال،sm
).
- اندازههای شبکه، میکسها و متغیرها بهروزرسانی شده است.
- ناودان های گرید اکنون دارای یک نقشه Sass هستند تا بتوانید عرض ناودان های خاصی را در هر نقطه شکست مشخص کنید.
- میکسین های شبکه به روز شده برای استفاده از
make-col-ready
مخلوط آماده سازی و amake-col
برای تنظیمflex
وmax-width
برای اندازه ستون های جداگانه. - نقاط شکست پرس و جوی رسانه سیستم شبکه و عرض کانتینر را تغییر داد تا ردیف شبکه جدید را در نظر بگیرد و اطمینان حاصل شود که ستون ها به طور مساوی بر
12
حداکثر عرض خود تقسیم می شوند. - نقاط شکست شبکه و عرض کانتینر اکنون از طریق نقشه های Sass (
$grid-breakpoints
و$container-max-widths
) به جای تعداد انگشت شماری از متغیرهای جداگانه مدیریت می شوند. اینها به طور کامل جایگزین@screen-*
متغیرها می شوند و به شما اجازه می دهند تا سطوح شبکه را به طور کامل سفارشی کنید. - درخواست های رسانه ای نیز تغییر کرده است. به جای اینکه هر بار اعلانهای درخواست رسانه خود را با همان مقدار تکرار کنیم، اکنون داریم
@include media-breakpoint-up/down/only
. حالا به جای نوشتن@media (min-width: @screen-sm-min) { ... }
، می توانید بنویسید@include media-breakpoint-up(sm) { ... }
.
اجزاء
- حذف پانلها، تصاویر کوچک و چاهها برای یک جزء جدید، کارتها .
- فونت نماد Glyphicons را حذف کرد. اگر به نمادها نیاز دارید، برخی از گزینه ها عبارتند از:
- نسخه بالادست Glyphicons
- Octicon ها
- فونت عالی
- برای لیستی از گزینه های جایگزین به صفحه Extend مراجعه کنید . پیشنهادات اضافی دارید؟ لطفا یک موضوع یا روابط عمومی را باز کنید.
- پلاگین Affix jQuery حذف شد.
- توصیه می کنیم
position: sticky
به جای آن استفاده کنید. برای جزئیات و توصیههای خاص polyfill به ورودی HTML5 لطفاً مراجعه کنید . یک پیشنهاد این است که از یک@supports
قانون برای اجرای آن استفاده کنید (به عنوان مثال،@supports (position: sticky) { ... }
)/ - اگر از Affix برای اعمال سبک های اضافی و غیر
position
سبک استفاده می کردید، ممکن است polyfills مورد استفاده شما را پشتیبانی نکند. یکی از گزینه ها برای چنین استفاده هایی کتابخانه شخص ثالث ScrollPos-Styler است.
- توصیه می کنیم
- جزء پیجر حذف شد زیرا اساساً دکمههای کمی سفارشی شده بود.
- تقریباً همه مؤلفهها را بازسازی کرد تا از انتخابگرهای کلاس غیر تودرتوی بیشتری به جای انتخابگرهای کودکان بیش از حد خاص استفاده کند.
بر اساس جزء
این لیست تغییرات کلیدی را بر اساس مؤلفه بین v3.xx و v4.0.0 برجسته می کند.
راه اندازی مجدد
راه اندازی مجدد Bootstrap 4 جدید است ، یک شیوه نامه جدید که بر اساس Normalize با سبک های بازنشانی تا حدودی عقیده ما ساخته شده است. انتخابگرهایی که در این فایل ظاهر می شوند فقط از عناصر استفاده می کنند—در اینجا هیچ کلاسی وجود ندارد. این امر سبکهای بازنشانی ما را از سبکهای مؤلفه ما برای یک رویکرد مدولارتر جدا میکند. برخی از مهمترین بازنشانیهایی که شامل box-sizing: border-box
تغییر، حرکت از واحد em
به rem
واحد در بسیاری از عناصر، سبکهای پیوند و بسیاری از بازنشانیهای عناصر فرم است.
تایپوگرافی
- همه
.text-
ابزارهای کمکی به_utilities.scss
فایل منتقل شدند. - حذف شد زیرا سبکهای
.page-header
آن را میتوان از طریق ابزارهای کاربردی اعمال کرد. .dl-horizontal
حذف شده است. در عوض، از کلاسهای ستون شبکه (یا میکسها) روی آن.row
و فرزندان استفاده کنید.<dl>
<dt>
<dd>
- بازطراحی بلوک نقل قول ها، انتقال سبک آنها از
<blockquote>
عنصر به یک کلاس واحد،.blockquote
. اصلاح.blockquote-reverse
کننده برای ابزارهای متنی حذف شد. .list-inline
اکنون نیاز دارد که آیتم های لیست فرزندانش.list-inline-item
کلاس جدید را برای آنها اعمال کند.
تصاویر
- تغییر نام
.img-responsive
به.img-fluid
. - تغییر نام داد
.img-rounded
به.rounded
- تغییر نام داد
.img-circle
به.rounded-circle
جداول
- تقریباً تمام نمونههای
>
انتخابگر حذف شدهاند، به این معنی که جداول تودرتو اکنون به طور خودکار سبکها را از والدین خود به ارث میبرند. این انتخابگرها و سفارشی سازی های بالقوه ما را بسیار ساده می کند. - برای سازگاری
.table-condensed
به تغییر نام داد ..table-sm
.table-inverse
یک گزینه جدید اضافه شد.- اصلاح کننده های هدر جدول اضافه شد:
.thead-default
و.thead-inverse
. - نام کلاسهای متنی را به
.table-
پیشوند - تغییر داد. از این رو.active
،،،،.success
و به ،،،، و ..warning
_ _.danger
.info
.table-active
.table-success
.table-warning
.table-danger
.table-info
تشکیل می دهد
- عنصر منتقل شده به
_reboot.scss
فایل بازنشانی می شود. - تغییر نام
.control-label
به.col-form-label
. - تغییر نام
.input-lg
و.input-sm
به.form-control-lg
و به.form-control-sm
ترتیب. .form-group-*
به خاطر سادگی کلاس ها را رها کرد . اکنون به جای آن از.form-control-*
کلاس ها استفاده کنید.- حذف شد و آن را با متن راهنما در سطح بلوک
.help-block
جایگزین کرد..form-text
برای متن راهنمای درون خطی و سایر گزینههای انعطافپذیر، از کلاسهای کاربردی مانند استفاده کنید.text-muted
. - افتاد
.radio-inline
و.checkbox-inline
. - ادغام
.checkbox
و.radio
به کلاس.form-check
های مختلف.form-check-*
. - فرم های افقی بازنگری شده:
- شرط
.form-horizontal
کلاس را کنار گذاشت. .form-group
دیگر سبکهای.row
via mixin را اعمال نمیکند، بنابراین.row
اکنون برای طرحبندیهای شبکه افقی (مثلاً<div class="form-group row">
) مورد نیاز است.- کلاس جدید
.col-form-label
به برچسبهای وسط عمودی با.form-control
s اضافه شد. .form-row
برای طرحبندیهای فرم جمعوجور با کلاسهای شبکهای جدید اضافه شده است (شما را.row
با a تعویض کنید.form-row
و بروید).
- شرط
- پشتیبانی از فرم های سفارشی اضافه شده (برای چک باکس ها، رادیوها، انتخاب ها و ورودی های فایل).
.has-error
,.has-warning
و.has-success
کلاس ها با اعتبار سنجی فرم HTML5 از طریق CSS:invalid
و:valid
شبه کلاس ها جایگزین شدند.- تغییر نام
.form-control-static
به.form-control-plaintext
.
دکمه ها
- تغییر نام
.btn-default
به.btn-secondary
. - کلاس را
.btn-xs
به طور کامل حذف کرد زیرا.btn-sm
نسبتاً بسیار کوچکتر از نسخه 3 است. - ویژگی دکمه Stateful افزونه
button.js
jQuery حذف شده است. این شامل$().button(string)
و$().button('reset')
روش ها می شود. ما توصیه می کنیم به جای آن از کمی جاوا اسکریپت سفارشی استفاده کنید، که این مزیت را دارد که دقیقاً همانطور که می خواهید رفتار کنید.- توجه داشته باشید که سایر ویژگی های افزونه (چک باکس دکمه ها، رادیو دکمه ها، دکمه های تک تاگل) در نسخه 4 حفظ شده است.
- دکمه ها را
[disabled]
به:disabled
عنوان پشتیبانی IE9+ تغییر دهید:disabled
. با این حالfieldset[disabled]
همچنان ضروری است زیرا مجموعه فیلدهای غیرفعال بومی هنوز در IE11 باگ هستند.
گروه دکمه
- کامپوننت را با flexbox بازنویسی کرد.
- حذف
.btn-group-justified
شد. به عنوان یک جایگزین می توانید<div class="btn-group d-flex" role="group"></div>
به عنوان یک بسته بندی در اطراف عناصر با.w-100
استفاده کنید. - با
.btn-group-xs
توجه به حذف کلاس، به طور کامل حذف شد.btn-xs
. - فاصله صریح بین گروه های دکمه در نوار ابزار دکمه حذف شد. اکنون از ابزارهای حاشیه استفاده کنید.
- اسناد بهبود یافته برای استفاده با اجزای دیگر.
کشویی
- از انتخابگرهای والد به کلاسهای تکی برای همه مؤلفهها، اصلاحکنندهها و غیره سوئیچ شد.
- سبکهای کرکرهای ساده شده برای اینکه دیگر با فلشهای رو به بالا یا پایین متصل به منوی کشویی ارسال نشود.
- اکنون می توان با
<div>
s یا<ul>
s کرکره ها را ساخت. - سبکهای کشویی و نشانهگذاری مجدد برای ارائه پشتیبانی آسان و داخلی از آیتمهای کشویی
<a>
و مبتنی بر آن.<button>
- تغییر نام
.divider
به.dropdown-divider
. - موارد کشویی اکنون نیاز دارند
.dropdown-item
. - ضامن های کشویی دیگر نیازی به صریح ندارند
<span class="caret"></span>
. این اکنون به طور خودکار از طریق CSS::after
در ارائه می.dropdown-toggle
شود.
سیستم شبکه ای
576px
یک نقطه شکست شبکه جدید به عنوان اضافه شده استsm
، به این معنی که اکنون پنج سطح کل وجود دارد (xs
،،،،،sm
و ) .md
lg
xl
- کلاس های اصلاح کننده گرید پاسخگو از
.col-{breakpoint}-{modifier}-{size}
به.{modifier}-{breakpoint}-{size}
برای کلاس های شبکه ساده تر تغییر نام داد. - کلاسهای اصلاحکننده فشار و کشش برای کلاسهای جدید مجهز به فلکسباکس حذف
order
شد. به عنوان مثال، به جای.col-8.push-4
و ، از و.col-4.pull-8
استفاده می کنید ..col-8.order-2
.col-4.order-1
- کلاس های کاربردی flexbox برای سیستم و اجزای شبکه اضافه شده است.
لیست کردن گروه ها
- کامپوننت را با flexbox بازنویسی کرد.
a.list-group-item
با یک کلاس صریح جایگزین شده است.list-group-item-action
، برای پیوند و نسخههای دکمهای از آیتمهای گروه فهرست.- کلاس اضافه شده
.list-group-flush
برای استفاده با کارت.
معین
- کامپوننت را با flexbox بازنویسی کرد.
- با توجه به حرکت به flexbox، تراز کردن نمادهای رد کردن در هدر احتمالاً شکسته است زیرا ما دیگر از شناور استفاده نمی کنیم. محتوای شناور اول است، اما با flexbox دیگر اینطور نیست. نمادهای رد کردن خود را به روز کنید تا بعد از عناوین مودال اصلاح شوند.
- گزینه (
remote
که می توانست برای بارگیری خودکار و تزریق محتوای خارجی به یک مدال استفاده شود) وloaded.bs.modal
رویداد مربوطه حذف شدند. توصیه میکنیم در عوض از قالب سمت کلاینت یا چارچوب اتصال داده استفاده کنید یا خودتان jQuery.load را فراخوانی کنید.
Navs
- کامپوننت را با flexbox بازنویسی کرد.
- تقریباً همه
>
انتخابگرها برای استایل سادهتر از طریق کلاسهای غیر تودرتو حذف شدند. - به جای انتخابگرهای خاص HTML مانند
.nav > li > a
، ما از کلاس های جداگانه برای.nav
s،.nav-item
s و.nav-link
s استفاده می کنیم. این باعث می شود HTML شما انعطاف پذیرتر شود و در عین حال توسعه پذیری بیشتری را به همراه دارد.
نوار ناوبری
نوار ناوبری به طور کامل در flexbox با پشتیبانی بهبود یافته برای تراز، پاسخگویی و سفارشی سازی بازنویسی شده است.
- رفتارهای نوار ناوبری پاسخگو اکنون از
.navbar
طریق موارد مورد نیاز.navbar-expand-{breakpoint}
در جایی که شما انتخاب میکنید کجا نوار ناوبر را جمع کنید به کلاس اعمال میشود. قبلاً این یک تغییر متغیر کمتر بود و نیاز به کامپایل مجدد داشت. .navbar-default
در حال حاضر است.navbar-light
، هر چند.navbar-dark
به همان شکل باقی مانده است. یکی از اینها در هر نوار ناوبری مورد نیاز است. با این حال، این کلاسها دیگرbackground-color
s را تنظیم نمیکنند. در عوض آنها اساساً فقط تأثیر می گذارندcolor
.- نوارهای ناوبری اکنون به نوعی اعلان پس زمینه نیاز دارند. از میان ابزارهای پسزمینه ما (
.bg-*
) را انتخاب کنید یا کلاسهای نور/عکوس بالا را برای سفارشیسازی دیوانهوار تنظیم کنید. - با توجه به سبکهای flexbox، نوارهای ناوبری اکنون میتوانند از ابزارهای flexbox برای گزینههای تراز آسان استفاده کنند.
.navbar-toggle
اکنون است.navbar-toggler
و دارای سبک های مختلف و نشانه گذاری داخلی است (سه<span>
ثانیه بیشتر نیست).- کلا
.navbar-form
کلاس رو رها کرد دیگر لازم نیست؛ در عوض، در.form-inline
صورت لزوم از ابزارهای حاشیه استفاده و اعمال کنید. - نوارهای ناوبری دیگر شامل
margin-bottom
یاborder-radius
به طور پیش فرض نیست. در صورت لزوم از خدمات شهری استفاده کنید. - همه نمونههای دارای نوارهای ناوبری بهروزرسانی شدهاند تا نشانهگذاری جدیدی را در بر گیرند.
صفحه بندی
- کامپوننت را با flexbox بازنویسی کرد.
- کلاسهای صریح (
.page-item
,.page-link
) اکنون برای فرزندان.pagination
s مورد نیاز است - کامپوننت
.pager
را به طور کامل حذف کرد زیرا کمی بیشتر از دکمه های طرح کلی سفارشی شده بود.
پودرهای سوخاری
- یک کلاس صریح،
.breadcrumb-item
, اکنون برای فرزندان.breadcrumb
s مورد نیاز است
برچسب ها و نشان ها
- ادغام شده
.label
و.badge
برای رفع ابهام از<label>
عنصر و ساده سازی اجزای مرتبط. .badge-pill
به عنوان اصلاح کننده برای ظاهر "قرص" گرد اضافه شده است.- نشانها دیگر بهطور خودکار در گروههای فهرست و سایر مؤلفهها شناور نمیشوند. اکنون کلاس های کاربردی برای آن مورد نیاز است.
.badge-default
حذف.badge-secondary
شده و برای مطابقت با کلاس های اصلاح کننده مؤلفه که در جاهای دیگر استفاده می شود، اضافه شده است.
پانل ها، تصاویر کوچک و چاه ها
برای قطعه کارت جدید به طور کامل حذف شد.
پانل ها
.panel
به.card
، اکنون با flexbox ساخته شده است..panel-default
حذف شده و بدون جایگزینی.panel-group
حذف شده و بدون جایگزینی.card-group
جایگزین نیست، متفاوت است..panel-heading
به.card-header
.panel-title
به.card-title
. بسته به ظاهر مورد نظر، ممکن است بخواهید از عناصر یا کلاسهای عنوان (به عنوان مثال<h3>
،.h3
) یا عناصر یا کلاسهای پررنگ (به عنوان مثال<strong>
،،<b>
).font-weight-bold
استفاده کنید. توجه داشته باشید که با وجود.card-title
نامگذاری مشابه، ظاهری متفاوت از.panel-title
..panel-body
به.card-body
.panel-footer
به.card-footer
.panel-primary
,.panel-success
,.panel-info
,.panel-warning
و.panel-danger
برای.bg-
,.text-
و.border
ابزارهای تولید شده از$theme-colors
نقشه Sass ما حذف شده اند.
پیش رفتن
.progress-bar-*
کلاس های متنی با.bg-*
ابزارهای کاربردی جایگزین شدند. به عنوان مثال،class="progress-bar progress-bar-danger"
تبدیل می شودclass="progress-bar bg-danger"
.- برای نوارهای
.active
پیشرفت متحرک با.progress-bar-animated
.
چرخ فلک
- کل مولفه را برای سادهسازی طراحی و استایل بازبینی کرد. ما سبک های کمتری برای شما داریم که می توانید آنها را نادیده بگیرید، نشانگرهای جدید و نمادهای جدید.
- تمام CSS از حالت تودرتو خارج شده و نام آن تغییر کرده است، مطمئن می شود که هر کلاس با پیشوند
.carousel-
.- برای آیتم های چرخ فلک
.next
،،،،.prev
و اکنون.left
،،، و ..right
.carousel-item-next
.carousel-item-prev
.carousel-item-left
.carousel-item-right
.item
هم اکنون.carousel-item
است.- برای کنترلهای prev/next،
.carousel-control.right
و.carousel-control.left
are now.carousel-control-next
و.carousel-control-prev
، به این معنی که دیگر نیازی به کلاس پایه خاصی ندارند.
- برای آیتم های چرخ فلک
- تمام استایلهای واکنشگرا حذف شد، به برنامههای کاربردی (مثلاً نشان دادن شرحها در نمایپورتهای خاص) و سبکهای سفارشی در صورت لزوم موکول شد.
- تصویر حذف شده برای تصاویر موجود در موارد چرخ فلک لغو می شود و به برنامه های کاربردی موکول می شود.
- مثال Carousel را بهینه کرد تا نشانهگذاری و سبکهای جدید را شامل شود.
جداول
- پشتیبانی از جداول تودرتوی استایلدار حذف شد. همه سبک های جدول اکنون در نسخه 4 برای انتخابگرهای ساده تر به ارث رسیده اند.
- نوع جدول معکوس اضافه شد.
خدمات رفاهی
- نمایش، پنهان و موارد دیگر:
- ابزارهای نمایشگر را پاسخگو کرد (به عنوان مثال،
.d-none
وd-{sm,md,lg,xl}-none
). - بخش عمده ای از برنامه های کاربردی برای ابزارهای نمایشگر
.hidden-*
جدید حذف شد. به عنوان مثال، به جای استفاده از . نام ابزارها را تغییر داد تا از طرح نامگذاری ابزار نمایش استفاده شود. اطلاعات بیشتر در بخش پاسخگوی ابزارهای این صفحه..hidden-sm-up
.d-sm-none
.hidden-print
.float-{sm,md,lg,xl}-{left,right,none}
کلاس هایی برای شناورهای پاسخگو اضافه شده و حذف شده اند.pull-left
و.pull-right
از آنجایی که به.float-left
و.float-right
.
- ابزارهای نمایشگر را پاسخگو کرد (به عنوان مثال،
- نوع:
- تغییرات پاسخگو به کلاس های تراز متن ما اضافه شد
.text-{sm,md,lg,xl}-{left,center,right}
.
- تغییرات پاسخگو به کلاس های تراز متن ما اضافه شد
- تراز و فاصله:
- ابزارهای حاشیه پاسخگو و بالشتک جدید برای همه طرفها، بهعلاوه کوتاهنویسی عمودی و افقی اضافه شده است.
- اضافه شدن قایق از ابزارهای فلکس باکس .
- برای کلاس
.center-block
جدید.mx-auto
حذف شده است.
- Clearfix بهروزرسانی شد تا پشتیبانی از نسخههای قدیمی مرورگر را کاهش دهد.
میکس های پیشوند فروشنده
میکسهای پیشوند فروشنده Bootstrap 3 ، که در نسخه 3.2.0 منسوخ شده بودند، در Bootstrap 4 حذف شدهاند. از آنجایی که ما از Autoprefixer استفاده میکنیم ، دیگر لازم نیست.
میکس های زیر را حذف کرد : animation
, animation-delay
, animation-direction
, animation-duration
, animation-fill-mode
, animation-iteration-count
, animation-name
, animation-timing-function
, backface-visibility
, box-sizing
, content-columns
, hyphens
, opacity
_ perspective
_ perspective-origin
_ rotate
_ rotateX
_ rotateY
_ scale
_ scaleX
_ scaleY
_ skew
_ transform-origin
_ transition-delay
_transition-duration
transition-property
transition-timing-function
transition-transform
translate
translate3d
user-select
مستندات
اسناد و مدارک ما در سراسر هیئت مدیره نیز ارتقا یافته است. پایین پایین اینجاست:
- ما هنوز از Jekyll استفاده می کنیم، اما افزونه هایی در ترکیب داریم:
bugify.rb
برای فهرست کردن موثر ورودیهای صفحه اشکالات مرورگر ما استفاده میشود .example.rb
یک فورک سفارشی ازhighlight.rb
پلاگین پیشفرض است که به شما امکان میدهد مدیریت کد مثال را آسانتر کند.callout.rb
یک چنگال سفارشی مشابه آن است، اما برای فراخوانی اسناد ویژه ما طراحی شده است.- jekyll-toc برای تولید فهرست مطالب ما استفاده می شود.
- تمام محتوای اسناد در Markdown (به جای HTML) برای ویرایش آسان تر بازنویسی شده است.
- صفحات برای محتوای ساده تر و سلسله مراتبی قابل دسترس تر سازماندهی شده اند.
- ما از CSS معمولی به SCSS منتقل شدیم تا از متغیرهای بوت استرپ، میکسها و موارد دیگر بهره ببریم.
ابزارهای پاسخگو
همه @screen-
متغیرها در نسخه 4.0.0 حذف شده اند. به جای آن از میکس های media-breakpoint-up()
, media-breakpoint-down()
یا media-breakpoint-only()
Sass یا $grid-breakpoints
نقشه Sass استفاده کنید.
کلاس های ابزار پاسخگو ما تا حد زیادی به نفع برنامه های display
کاربردی واضح حذف شده اند.
- کلاس ها
.hidden
و.show
به دلیل تضاد با jQuery$(...).hide()
و$(...).show()
متدها حذف شده اند. در عوض، سعی کنید[hidden]
ویژگی را تغییر دهید یا از سبک های درون خطی مانندstyle="display: none;"
و استفاده کنیدstyle="display: block;"
. - همه
.hidden-
کلاس ها حذف شده اند، به جز ابزارهای چاپی که تغییر نام داده اند.- از نسخه 3 حذف شد:
.hidden-xs
.hidden-sm
.hidden-md
.hidden-lg
.visible-xs-block
.visible-xs-inline
.visible-xs-inline-block
.visible-sm-block
.visible-sm-inline
.visible-sm-inline-block
.visible-md-block
.visible-md-inline
.visible-md-inline-block
.visible-lg-block
.visible-lg-inline
.visible-lg-inline-block
- از نسخه 4 آلفا حذف شد:
.hidden-xs-up
.hidden-xs-down
.hidden-sm-up
.hidden-sm-down
.hidden-md-up
.hidden-md-down
.hidden-lg-up
.hidden-lg-down
- از نسخه 3 حذف شد:
- ابزارهای چاپ دیگر با
.hidden-
یا شروع نمی شوند.visible-
، بلکه با.d-print-
.- نام های قدیمی:
.visible-print-block
,.visible-print-inline
,.visible-print-inline-block
,.hidden-print
- کلاس های جدید:
.d-print-block
,.d-print-inline
,.d-print-inline-block
,.d-print-none
- نام های قدیمی:
به جای استفاده از .visible-*
کلاس های صریح، شما یک عنصر را با پنهان نکردن آن در اندازه صفحه نمایش، قابل مشاهده می کنید. می توانید یک .d-*-none
کلاس را با یک .d-*-block
کلاس ترکیب کنید تا یک عنصر را فقط در یک بازه زمانی مشخص از اندازه صفحه نمایش .d-none.d-md-block.d-xl-none
نشان دهید (مثلاً عنصر را فقط در دستگاه های متوسط و بزرگ نشان می دهد).
توجه داشته باشید که تغییرات در نقاط شکست شبکه در v4 به این معنی است که برای دستیابی به نتایج یکسان باید یک نقطه شکست بزرگتر بروید. کلاسهای کاربردی جدید پاسخگو سعی نمیکنند موارد کمتر رایجی را که در آن دید یک عنصر را نمیتوان بهعنوان یک محدوده پیوسته از اندازههای viewport بیان کرد، تطبیق داد. در عوض باید از CSS سفارشی در چنین مواردی استفاده کنید.