v4 میں منتقلی
بوٹسٹریپ 4 پورے پروجیکٹ کی ایک بڑی تحریر ہے۔ سب سے زیادہ قابل ذکر تبدیلیوں کا خلاصہ ذیل میں دیا گیا ہے، اس کے بعد متعلقہ اجزاء میں مزید مخصوص تبدیلیاں کی گئی ہیں۔
مستحکم تبدیلیاں
بیٹا 3 سے ہمارے مستحکم v4.x ریلیز میں منتقل ہونے سے، کوئی توڑ تبدیلیاں نہیں ہیں، لیکن کچھ قابل ذکر تبدیلیاں ہیں۔
پرنٹنگ
-
فکسڈ ٹوٹا ہوا پرنٹ افادیت. پہلے،
.d-print-*
کلاس کا استعمال غیر متوقع طور پر کسی دوسری.d-*
کلاس کو ختم کر دیتا تھا۔@media print
اب، وہ ہماری دیگر ڈسپلے یوٹیلیٹیز سے میل کھاتے ہیں اور صرف اس میڈیا ( ) پر لاگو ہوتے ہیں ۔ -
دیگر افادیت سے ملنے کے لیے دستیاب پرنٹ ڈسپلے یوٹیلیٹیز کو بڑھایا گیا۔ بیٹا 3 اور اس سے بڑے کے پاس صرف
block
,inline-block
,inline
, اورnone
تھا۔ مستحکم v4 شامل کیا گیاflex
,inline-flex
,table
,table-row
, andtable-cell
. -
نئے پرنٹ شیلیوں کے ساتھ براؤزرز میں فکسڈ پرنٹ پیش نظارہ رینڈرنگ جو وضاحت کرتی
@page
size
ہے۔
بیٹا 3 تبدیلیاں
جبکہ بیٹا 2 نے بیٹا مرحلے کے دوران ہماری بڑی تبدیلیوں کو دیکھا، لیکن ہمارے پاس ابھی بھی کچھ ایسے ہیں جن کو بیٹا 3 ریلیز میں حل کرنے کی ضرورت ہے۔ یہ تبدیلیاں لاگو ہوتی ہیں اگر آپ Beta 2 سے Beta 3 یا Bootstrap کے کسی پرانے ورژن کو اپ ڈیٹ کر رہے ہیں۔
متفرق
$thumbnail-transition
غیر استعمال شدہ متغیر کو ہٹا دیا ۔ ہم کچھ بھی منتقل نہیں کر رہے تھے، لہذا یہ صرف اضافی کوڈ تھا۔- npm پیکیج میں اب ہمارے سورس اور ڈسٹ فائلوں کے علاوہ کوئی فائل شامل نہیں ہے۔ اگر آپ ان پر بھروسہ کرتے ہیں اور
node_modules
فولڈر کے ذریعے ہماری اسکرپٹس چلا رہے ہیں، تو آپ کو اپنے ورک فلو کو اپنانا چاہیے۔
فارمز
-
حسب ضرورت اور ڈیفالٹ دونوں چیک باکسز اور ریڈیوز کو دوبارہ لکھیں۔ اب، دونوں کا HTML ڈھانچہ مماثل ہے (
<div>
sibling<input>
اور<label>
) کے ساتھ بیرونی اور ایک ہی لے آؤٹ اسٹائلز (اسٹیکڈ ڈیفالٹ، موڈیفائر کلاس کے ساتھ ان لائن)۔ یہ ہمیں ان پٹ کی حالت کی بنیاد پر لیبل کو اسٹائل کرنے کی اجازت دیتا ہے،disabled
خصوصیت کے لیے سپورٹ کو آسان بناتا ہے (پہلے پیرنٹ کلاس کی ضرورت ہوتی ہے) اور ہمارے فارم کی توثیق کو بہتر طریقے سے سپورٹ کرتا ہے۔اس کے حصے کے طور پر، ہم نے
background-image
حسب ضرورت فارم کے چیک باکسز اور ریڈیوز پر متعدد s کے انتظام کے لیے CSS کو تبدیل کر دیا ہے۔ پہلے، اب ہٹائے گئے.custom-control-indicator
عنصر میں پس منظر کا رنگ، گریڈینٹ، اور SVG آئیکن ہوتا تھا۔ پس منظر کے میلان کو حسب ضرورت بنانے کا مطلب ہے کہ جب بھی آپ کو صرف ایک کو تبدیل کرنے کی ضرورت ہو تو ان سب کو تبدیل کرنا۔ اب، ہمارے پاس.custom-control-label::before
فل اور گریڈینٹ ہے اور.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 متغیر میں تبدیلی موصول ہوئی۔ یہ اب ایک نیسٹڈ ساس کا نقشہ نہیں ہے اور اب صرف ایک سٹرنگ کو طاقت دیتا ہے —Browse
بٹن جیسا کہ اب ہمارے ساس سے پیدا ہونے والا واحد سیوڈو عنصر ہے۔ متن ابChoose file
سے آتا ہے.custom-file-label
۔
ان پٹ گروپس
-
ان پٹ گروپ ایڈونز اب ان پٹ کی نسبت ان کی جگہ کے لیے مخصوص ہیں۔ ہم نے چھوڑ دیا ہے
.input-group-addon
اور.input-group-btn
دو نئی کلاسوں کے لیے،.input-group-prepend
اور.input-group-append
. ہمارے سی ایس ایس کے زیادہ تر حصے کو آسان بناتے ہوئے، آپ کو اب واضح طور پر ایک ضمیمہ یا ایک پری پینڈ استعمال کرنا چاہیے۔ ضمیمہ یا پہلے سے منسلک کے اندر، اپنے بٹن کو اس طرح رکھیں جیسے وہ کہیں اور موجود ہوں گے، لیکن متن کو میں لپیٹیں.input-group-text
۔ -
توثیق کے انداز اب معاون ہیں، جیسا کہ متعدد ان پٹ ہیں (حالانکہ آپ فی گروپ صرف ایک ان پٹ کی توثیق کر سکتے ہیں)۔
-
سائز سازی کی کلاسیں والدین پر ہونی چاہئیں
.input-group
نہ کہ انفرادی شکل کے عناصر پر۔
بیٹا 2 تبدیلیاں
بیٹا میں رہتے ہوئے، ہمارا مقصد ہے کہ کوئی تبدیلیاں نہ ہوں۔ تاہم، چیزیں ہمیشہ منصوبہ بندی کے مطابق نہیں ہوتیں۔ Beta 1 سے Beta 2 میں منتقل ہوتے وقت ذہن میں رکھنے والی اہم تبدیلیاں ذیل میں ہیں۔
توڑنے
$badge-color
متغیر اور اس کا استعمال پر ہٹا دیا گیا.badge
۔ ہم رنگ کنٹراسٹ فنکشن کا استعمال کرتے ہیں اس کیcolor
بنیاد پر منتخب کرنے کے لیےbackground-color
، اس لیے متغیر غیر ضروری ہے۔- CSS مقامی فلٹر کے ساتھ تنازعات کو توڑنے سے بچنے کے لیے
grayscale()
فنکشن کا نام تبدیل کر دیا گیا۔gray()
grayscale
- دوسری جگہوں پر استعمال ہونے والی ہماری رنگ سکیموں سے مماثل
.table-inverse
،.thead-inverse
, اور.thead-default
to.*-dark
اور کا نام تبدیل کر دیا گیا۔.*-light
- ریسپانسیو ٹیبلز اب ہر گرڈ بریک پوائنٹ کے لیے کلاسز تیار کرتی ہیں۔ یہ بیٹا 1 سے اس لحاظ سے ٹوٹ جاتا ہے کہ
.table-responsive
آپ جو استعمال کر رہے ہیں اس کی طرح.table-responsive-md
ہے۔ آپ اب استعمال کرسکتے ہیں.table-responsive
یا.table-responsive-{sm,md,lg,xl}
ضرورت کے مطابق۔ - پیکیج مینیجر کے طور پر ڈراپ بوور سپورٹ کو متبادل کے لیے فرسودہ کر دیا گیا ہے (مثلاً، یارن یا این پی ایم)۔ تفصیلات کے لیے bower/bower#2298 دیکھیں۔
- بوٹسٹریپ کو اب بھی jQuery 1.9.1 یا اس سے زیادہ کی ضرورت ہے، لیکن آپ کو مشورہ دیا جاتا ہے کہ ورژن 3.x استعمال کریں کیونکہ v3.x کے تعاون یافتہ براؤزرز وہ ہیں جو Bootstrap کو سپورٹ کرتا ہے اور v3.x میں کچھ حفاظتی اصلاحات ہیں۔
.form-control-label
غیر استعمال شدہ کلاس کو ہٹا دیا ۔ اگر آپ نے اس کلاس کا استعمال کیا ہے، تو یہ اس کلاس کا ڈپلیکیٹ تھا جس نے افقی شکل کے لے آؤٹ میں اس سے منسلک ان پٹ کے ساتھ.col-form-label
عمودی طور پر مرکز بنایا تھا۔<label>
color-yiq
کو ایک مکسین سے تبدیل کیا جس میںcolor
پراپرٹی کو ایک فنکشن میں شامل کیا گیا ہے جو ایک قدر واپس کرتا ہے، جس سے آپ اسے کسی بھی CSS پراپرٹی کے لیے استعمال کر سکتے ہیں۔ مثال کے طور پر، اس کے بجائےcolor-yiq(#000)
، آپ لکھیںcolor: color-yiq(#000);
گے۔
جھلکیاں
pointer-events
ماڈلز پر نیا استعمال متعارف کرایا ۔ بیرونی اپنی مرضی کے مطابق کلک ہینڈلنگ.modal-dialog
کے ساتھ واقعات سے گزرتا ہےpointer-events: none
(کسی بھی کلک کے لیے صرف سننا ممکن بناتا ہے.modal-backdrop
)، اور پھر اصل.modal-content
کے لیے اس کا مقابلہ کرتاpointer-events: auto
ہے۔
خلاصہ
یہ وہ بڑی ٹکٹ آئٹمز ہیں جن کے بارے میں آپ v3 سے v4 کی طرف جاتے وقت آگاہ ہونا چاہیں گے۔
براؤزر سپورٹ
- IE8، IE9، اور iOS 6 سپورٹ کو چھوڑ دیا گیا۔ v4 اب صرف IE10+ اور iOS 7+ ہے۔ ان سائٹس کے لیے جن میں سے کسی ایک کی ضرورت ہے، v3 استعمال کریں۔
- Android v5.0 Lollipop کے براؤزر اور WebView کے لیے آفیشل سپورٹ شامل کر دیا گیا۔ اینڈرائیڈ براؤزر اور ویب ویو کے پہلے ورژن صرف غیر سرکاری طور پر تعاون یافتہ ہیں۔
عالمی تبدیلیاں
- Flexbox بطور ڈیفالٹ فعال ہے۔ عام طور پر اس کا مطلب ہے فلوٹس سے دور ہونا اور ہمارے تمام اجزاء سے زیادہ۔
- ہماری سورس CSS فائلوں کے لیے Less سے Sass میں تبدیل ہوا ۔
- ہمارے بنیادی CSS یونٹ کے طور پر سے پر سوئچ کیا
px
گیاrem
، حالانکہ میڈیا کے سوالات اور گرڈ رویے کے لیے پکسلز اب بھی استعمال کیے جاتے ہیں کیونکہ ڈیوائس ویو پورٹ قسم کے سائز سے متاثر نہیں ہوتے ہیں۔ - عالمی فونٹ کا سائز بڑھ
14px
کر16px
. - پانچواں آپشن شامل کرنے کے لیے گرڈ ٹائرز کو نئے سرے سے بنایا گیا (چھوٹے آلات کو
576px
اور نیچے سے ایڈریس کرنا) اور-xs
ان کلاسز سے انفکس کو ہٹا دیا۔ مثال:.col-6.col-sm-4.col-md-3
. - علیحدہ اختیاری تھیم کو SCSS متغیرات (مثلاً،
$enable-gradients: true
) کے ذریعے قابل ترتیب اختیارات کے ساتھ بدل دیا۔ - Grunt کے بجائے npm اسکرپٹس کی ایک سیریز کو استعمال کرنے کے لیے سسٹم کی اوور ہالڈ بنائیں۔
package.json
تمام اسکرپٹس کے لیے دیکھیں ، یا مقامی ترقیاتی ضروریات کے لیے ہمارا پروجیکٹ ریڈمی دیکھیں۔ - بوٹسٹریپ کا غیر جوابی استعمال مزید تعاون یافتہ نہیں ہے۔
- مزید وسیع سیٹ اپ دستاویزات اور حسب ضرورت تعمیرات کے حق میں آن لائن کسٹمائزر کو چھوڑ دیا۔
- عام سی ایس ایس پراپرٹی ویلیو جوڑوں اور مارجن/پیڈنگ اسپیسنگ شارٹ کٹس کے لیے درجنوں نئی یوٹیلیٹی کلاسز شامل کی گئیں۔
گرڈ سسٹم
- flexbox میں منتقل کر دیا گیا۔
- گرڈ مکسنس اور پہلے سے طے شدہ کلاسز میں فلیکس باکس کے لیے سپورٹ شامل کر دی گئی۔
- flexbox کے حصے کے طور پر، عمودی اور افقی صف بندی کی کلاسوں کے لیے تعاون شامل ہے۔
- اپ ڈیٹ کردہ گرڈ کلاس کے نام اور ایک نیا گرڈ ٹائر۔
- مزید دانے دار کنٹرول کے لیے نیچے ایک نیا
sm
گرڈ ٹائر شامل کیا گیا۔768px
اب ہمارے پاس ہےxs
,sm
,md
,lg
, اورxl
. اس کا مطلب یہ بھی ہے کہ ہر درجے کو ایک سطح سے ٹکرا دیا گیا ہے (لہذا.col-md-6
v3 میں اب.col-lg-6
v4 میں ہے)۔ xs
گرڈ کلاسز میں ترمیم کی گئی ہے تاکہ انفکس کی ضرورت نہ ہو تاکہ زیادہ درست طریقے سے اس بات کی نمائندگی کی جا سکے کہ وہmin-width: 0
ایک سیٹ پکسل ویلیو پر اسٹائل لگانا شروع کر دیتے ہیں۔ اس کے بجائے.col-xs-6
، یہ اب ہے.col-6
۔ دیگر تمام گرڈ درجات کو انفکس کی ضرورت ہوتی ہے (مثال کے طور پر،sm
)۔
- مزید دانے دار کنٹرول کے لیے نیچے ایک نیا
- اپ ڈیٹ کردہ گرڈ سائز، مکسنس، اور متغیرات۔
- گرڈ گٹر کے پاس اب ایک ساس نقشہ ہے لہذا آپ ہر بریک پوائنٹ پر گٹر کی مخصوص چوڑائی بتا سکتے ہیں۔
make-col-ready
ایک پریپ مکسین کو استعمال کرنے کے لیے اپ ڈیٹ کردہ گرڈ مکسنس اورmake-col
سیٹ کرنے کے لیےflex
اورmax-width
انفرادی کالم کے سائز کے لیے۔- گرڈ سسٹم کے میڈیا استفسار کے بریک پوائنٹس اور کنٹینر کی چوڑائیوں کو تبدیل کر کے نئے گرڈ ٹائر کے حساب سے اور اس بات کو یقینی بنائیں کہ کالم
12
اپنی زیادہ سے زیادہ چوڑائی کے حساب سے یکساں طور پر تقسیم ہوں۔ - گرڈ بریک پوائنٹس اور کنٹینر کی چوڑائیوں کو اب مٹھی بھر الگ الگ متغیرات کی بجائے ساس نقشہ جات (
$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 کا اپ اسٹریم ورژن
- اوکٹون
- فونٹ بہت اچھے
- متبادلات کی فہرست کے لیے توسیعی صفحہ دیکھیں ۔ اضافی تجاویز ہیں؟ براہ کرم کوئی مسئلہ یا PR کھولیں۔
- Affix jQuery پلگ ان کو گرا دیا۔
- ہم
position: sticky
اس کے بجائے استعمال کرنے کی تجویز کرتے ہیں۔ تفصیلات اور مخصوص پولی فل کی سفارشات کے لیے HTML5 براہ کرم اندراج دیکھیں ۔ ایک تجویز یہ ہے کہ@supports
اسے نافذ کرنے کے لیے ایک اصول استعمال کیا جائے (مثال کے طور پر،@supports (position: sticky) { ... }
) - اگر آپ اضافی، غیر
position
طرزیں لگانے کے لیے Affix کا استعمال کر رہے تھے، تو ہو سکتا ہے کہ پولی فلز آپ کے استعمال کے معاملے کی حمایت نہ کریں۔ اس طرح کے استعمال کے لیے ایک آپشن تھرڈ پارٹی ScrollPos-Styler لائبریری ہے۔
- ہم
- پیجر جزو کو گرا دیا کیونکہ یہ بنیادی طور پر تھوڑا سا حسب ضرورت بٹن تھا۔
- زیادہ سے زیادہ مخصوص بچوں کے سلیکٹرز کے بجائے زیادہ غیر نیسٹڈ کلاس سلیکٹرز استعمال کرنے کے لیے تقریباً تمام اجزاء کو ری فیکٹر کیا۔
جزو کے لحاظ سے
یہ فہرست v3.xx اور v4.0.0 کے درمیان جزو کے لحاظ سے اہم تبدیلیوں کو نمایاں کرتی ہے۔
دوبارہ شروع کریں۔
Bootstrap 4 کے لیے نیا Reboot ہے ، ایک نئی اسٹائل شیٹ جو ہمارے اپنے کسی حد تک رائے والے ری سیٹ اسٹائل کے ساتھ نارملائز پر بنتی ہے۔ اس فائل میں ظاہر ہونے والے سلیکٹرز صرف عناصر کا استعمال کرتے ہیں—یہاں کوئی کلاس نہیں ہے۔ یہ زیادہ ماڈیولر اپروچ کے لیے ہمارے ری سیٹ اسٹائلز کو ہمارے اجزاء کے انداز سے الگ کرتا ہے۔ اس میں شامل کچھ سب سے اہم ری سیٹس میں تبدیلیاں شامل ہیں ، بہت سے عناصر پر اکائیوں سے منتقل ہونا، لنک کی طرزیں، اور بہت سے عنصر کی دوبارہ ترتیب 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-
-prefix رکھنے کے لیے۔ اس لیے.active
,.success
,.warning
,.danger
اور.info
to.table-active
,.table-success
,.table-warning
,.table-danger
and.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
s کے ساتھ عمودی طور پر سینٹر لیبلز میں نئی کلاس شامل.form-control
کی گئی۔.form-row
گرڈ کلاسز کے ساتھ کمپیکٹ فارم لے آؤٹس کے لیے نیا شامل کیا گیا (اپنے.row
کے لیے تبدیل کریں.form-row
اور جائیں)۔
- اپنی مرضی کے مطابق فارم سپورٹ (چیک باکسز، ریڈیوز، سلیکٹس، اور فائل ان پٹس کے لیے) شامل کیا گیا۔
- CSS اور سیوڈو کلاسز کے ذریعے HTML5 فارم کی توثیق کے ساتھ تبدیل کیا گیا
.has-error
،.has-warning
اور کلاسز۔.has-success
:invalid
:valid
- نام بدل کر رکھ دیا
.form-control-static
گیا.form-control-plaintext
۔
بٹن
- نام بدل کر رکھ دیا
.btn-default
گیا.btn-secondary
۔ .btn-xs
کلاس کو مکمل طور پر گرا دیا جیسا.btn-sm
کہ متناسب طور پر v3 کے مقابلے میں بہت چھوٹا ہے۔- jQuery پلگ ان کی اسٹیٹفول بٹن خصوصیت کو
button.js
چھوڑ دیا گیا ہے۔ اس میں$().button(string)
اور$().button('reset')
طریقے شامل ہیں۔ ہم اس کے بجائے تھوڑا سا حسب ضرورت JavaScript استعمال کرنے کا مشورہ دیتے ہیں، جس کا فائدہ بالکل اسی طرح سے برتا جائے گا جس طرح آپ چاہتے ہیں۔- نوٹ کریں کہ پلگ ان کی دیگر خصوصیات (بٹن چیک باکسز، بٹن ریڈیوز، سنگل ٹوگل بٹن) کو v4 میں برقرار رکھا گیا ہے۔
- بٹنوں
[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
, andxl
) ہیں۔ - آسان گرڈ کلاسز کے لیے ریسپانسیو
.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 کے ساتھ جزو کو دوبارہ لکھا۔
- فہرست گروپ آئٹمز کے اسٹائل لنک اور بٹن ورژن کے لیے
a.list-group-item
ایک واضح کلاس، , سے بدل دیا گیا۔.list-group-item-action
.list-group-flush
کارڈز کے ساتھ استعمال کے لیے کلاس شامل کی گئی۔
موڈل
- flexbox کے ساتھ جزو کو دوبارہ لکھا۔
- فلیکس باکس میں منتقل ہونے کے پیش نظر، ہیڈر میں برخاست آئیکنز کی سیدھ ٹوٹ گئی ہے کیونکہ ہم اب فلوٹس استعمال نہیں کر رہے ہیں۔ فلوٹ شدہ مواد پہلے آتا ہے، لیکن فلیکس باکس کے ساتھ اب ایسا نہیں ہے۔ درست کرنے کے لیے موڈل ٹائٹلز کے بعد آنے کے لیے اپنے برخاست آئیکنز کو اپ ڈیٹ کریں۔
- آپشن (جس کا
remote
استعمال خودکار طور پر بیرونی مواد کو موڈل میں لوڈ اور انجیکشن کرنے کے لیے کیا جا سکتا ہے) اور متعلقہloaded.bs.modal
ایونٹ کو ہٹا دیا گیا۔ ہم کلائنٹ سائیڈ ٹیمپلیٹنگ یا ڈیٹا بائنڈنگ فریم ورک استعمال کرنے یا خود jQuery.load کال کرنے کی تجویز کرتے ہیں۔
نیوس
- flexbox کے ساتھ جزو کو دوبارہ لکھا۔
>
غیر نیسٹڈ کلاسز کے ذریعے آسان اسٹائلنگ کے لیے تقریباً تمام سلیکٹرز کو چھوڑ دیا۔- HTML کے لیے مخصوص سلیکٹرز کی بجائے ، ہم s، s، اور s
.nav > li > a
کے لیے الگ الگ کلاسز استعمال کرتے ہیں ۔ یہ آپ کے HTML کو مزید لچکدار بناتا ہے جبکہ توسیع پذیری میں اضافہ ہوتا ہے۔.nav
.nav-item
.nav-link
نوبار
نیوبار کو مکمل طور پر فلیکس باکس میں دوبارہ لکھا گیا ہے جس میں صف بندی، ردعمل اور حسب ضرورت کے لیے بہتر سپورٹ ہے۔
- ریسپانسیو نیوبار رویے اب
.navbar
کلاس پر مطلوبہ.navbar-expand-{breakpoint}
کے ذریعے لاگو کیے جاتے ہیں جہاں آپ انتخاب کرتے ہیں کہ نیوبار کو کہاں ختم کرنا ہے۔ پہلے یہ ایک کم متغیر ترمیم تھی اور اسے دوبارہ مرتب کرنا ضروری تھا۔ .navbar-default
اب ہے.navbar-light
، حالانکہ.navbar-dark
وہی رہتا ہے۔ ہر نوبار پر ان میں سے ایک کی ضرورت ہے۔ تاہم، یہ کلاسز اب سیٹ نہیں کرتیںbackground-color
؛ اس کے بجائے وہ بنیادی طور پر صرف متاثر کرتے ہیںcolor
۔- Navbars کو اب کسی قسم کے پس منظر کے اعلان کی ضرورت ہوتی ہے۔ ہماری بیک گراؤنڈ یوٹیلیٹیز ( ) میں سے انتخاب کریں یا دیوانہ حسب ضرورت کے لیے
.bg-*
اوپر دی گئی لائٹ/انورس کلاسز کے ساتھ خود سیٹ کریں ۔ - flexbox سٹائل کو دیکھتے ہوئے، navbars اب آسان صف بندی کے اختیارات کے لیے flexbox یوٹیلیٹیز استعمال کر سکتے ہیں۔
.navbar-toggle
اب ہے.navbar-toggler
اور اس کے مختلف انداز اور اندرونی مارک اپ ہیں (زیادہ تین<span>
سیکنڈ نہیں)۔.navbar-form
کلاس کو مکمل طور پر چھوڑ دیا ۔ اب اس کی ضرورت نہیں رہی۔ اس کے بجائے، صرف.form-inline
ضرورت کے مطابق مارجن یوٹیلیٹیز استعمال کریں اور لاگو کریں۔- Navbars میں اب شامل نہیں ہے
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
, اور ہمارے Sass نقشے سے تیار کردہ , , اور افادیت.panel-danger
کے لیے چھوڑ دیا گیا ہے ۔.bg-
.text-
.border
$theme-colors
پیش رفت
.progress-bar-*
سیاق و سباق کی کلاسوں کو.bg-*
یوٹیلیٹیز سے بدل دیا گیا۔ مثال کے طور پر،class="progress-bar progress-bar-danger"
بن جاتا ہےclass="progress-bar bg-danger"
۔.active
اینیمیٹڈ پروگریس بارز کے ساتھ تبدیل کیا گیا.progress-bar-animated
۔
Carousel
- ڈیزائن اور اسٹائل کو آسان بنانے کے لیے پورے اجزاء کی اوور ہال کی گئی۔ ہمارے پاس آپ کو اوور رائڈ کرنے کے لیے کم اسٹائلز، نئے اشارے اور نئے آئیکنز ہیں۔
- تمام CSS کو غیر نیسٹڈ کر دیا گیا ہے اور اس کا نام تبدیل کر دیا گیا ہے، اس بات کو یقینی بناتے ہوئے کہ ہر کلاس کے ساتھ سابقہ لگا ہوا
.carousel-
ہے۔- carousel آئٹمز کے لیے،
.next
,.prev
,.left
, اور.right
اب ہیں.carousel-item-next
,.carousel-item-prev
,.carousel-item-left
, and.carousel-item-right
. .item
اب بھی.carousel-item
ہے- پچھلے/اگلے کنٹرولز کے لیے،
.carousel-control.right
اور.carousel-control.left
اب ہیں.carousel-control-next
اور.carousel-control-prev
، یعنی انہیں اب کسی مخصوص بیس کلاس کی ضرورت نہیں ہے۔
- carousel آئٹمز کے لیے،
- ضرورت کے مطابق تمام ریسپانسیو اسٹائلنگ کو ہٹا دیا گیا، یوٹیلیٹیز کو موخر کر دیا گیا (مثلاً کچھ ویو پورٹ پر کیپشن دکھانا) اور حسب ضرورت انداز۔
- افادیت کو موخر کرتے ہوئے، carousel آئٹمز میں تصاویر کے لیے ہٹائی گئی تصویر اوور رائیڈز۔
- نئے مارک اپ اور سٹائلز کو شامل کرنے کے لیے Carousel مثال کو موافق بنایا۔
میزیں
- اسٹائلڈ نیسٹڈ ٹیبلز کے لیے سپورٹ کو ہٹا دیا گیا۔ تمام ٹیبل اسٹائل اب آسان سلیکٹرز کے لیے v4 میں وراثت میں ملے ہیں۔
- الٹا ٹیبل ویرینٹ شامل کیا گیا۔
افادیت
- ڈسپلے، پوشیدہ، اور مزید:
- ڈسپلے یوٹیلیٹیز کو ریسپانسیو بنایا (مثلاً،
.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
کلاس کے لیے چھوڑ دیا گیا۔
- پرانے براؤزر ورژن کے لیے سپورٹ چھوڑنے کے لیے کلیئر فکس کو اپ ڈیٹ کیا گیا۔
وینڈر پریفکس مکسنس
بوٹسٹریپ 3 کے وینڈر پریفکس مکسینز، جو v3.2.0 میں فرسودہ تھے، بوٹسٹریپ 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 ہمارے مشمولات کے جدول کو بنانے کے لیے استعمال کیا جاتا ہے۔
- آسان ترمیم کے لیے تمام دستاویزات کے مواد کو مارک ڈاؤن (HTML کی بجائے) میں دوبارہ لکھا گیا ہے۔
- صفحات کو آسان مواد اور زیادہ قابل رسائی درجہ بندی کے لیے دوبارہ ترتیب دیا گیا ہے۔
- ہم بوٹسٹریپ کے متغیرات، مکسنس وغیرہ سے بھرپور فائدہ اٹھانے کے لیے باقاعدہ CSS سے SCSS میں چلے گئے۔
ذمہ دار افادیت
@screen-
v4.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-
کلاسوں کو ہٹا دیا گیا ہے، پرنٹ یوٹیلیٹیز کے علاوہ جن کا نام تبدیل کر دیا گیا ہے۔- v3 سے ہٹا دیا گیا:
.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
- v4 الفا سے ہٹا دیا گیا:
.hidden-xs-up
.hidden-xs-down
.hidden-sm-up
.hidden-sm-down
.hidden-md-up
.hidden-md-down
.hidden-lg-up
.hidden-lg-down
- v3 سے ہٹا دیا گیا:
- پرنٹ یوٹیلیٹیز اب
.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 میں گرڈ بریک پوائنٹس میں تبدیلیوں کا مطلب ہے کہ آپ کو وہی نتائج حاصل کرنے کے لیے ایک بریک پوائنٹ بڑا کرنے کی ضرورت ہوگی۔ نئی ریسپانسیو یوٹیلیٹی کلاسز کم عام کیسز کو ایڈجسٹ کرنے کی کوشش نہیں کرتی ہیں جہاں کسی عنصر کی مرئیت کو ویوپورٹ سائز کی ایک متصل رینج کے طور پر ظاہر نہیں کیا جا سکتا ہے۔ اس کے بجائے آپ کو ایسے معاملات میں اپنی مرضی کے مطابق CSS استعمال کرنے کی ضرورت ہوگی۔