রিবুট করুন
রিবুট, একটি একক ফাইলে উপাদান-নির্দিষ্ট CSS পরিবর্তনের একটি সংগ্রহ, একটি মার্জিত, সামঞ্জস্যপূর্ণ, এবং সহজ বেসলাইন প্রদান করার জন্য বুটস্ট্র্যাপ কিকস্টার্ট করুন।
এপ্রোচ
শুধুমাত্র উপাদান নির্বাচক ব্যবহার করে কিছুটা মতামতযুক্ত শৈলী সহ অনেক এইচটিএমএল উপাদান প্রদান করে, নর্মালাইজের উপর রিবুট তৈরি করে। অতিরিক্ত স্টাইলিং শুধুমাত্র ক্লাসের সাথে করা হয়। উদাহরণস্বরূপ, আমরা <table>একটি সহজ বেসলাইনের জন্য কিছু শৈলী রিবুট করি এবং পরে .table, .table-bordered, এবং আরও অনেক কিছু প্রদান করি।
রিবুটে কী ওভাররাইড করতে হবে তা বেছে নেওয়ার জন্য এখানে আমাদের নির্দেশিকা এবং কারণ রয়েছে:
- স্কেলেবল কম্পোনেন্ট স্পেসিংয়ের জন্য s
remএর পরিবর্তে s ব্যবহার করতে কিছু ব্রাউজার ডিফল্ট মান আপডেট করুন।em - এড়িয়ে চলুন
margin-top। উল্লম্ব মার্জিন ভেঙে পড়তে পারে, অপ্রত্যাশিত ফলাফল দেয়। আরো গুরুত্বপূর্ণ যদিও, একটি একক দিকmarginএকটি সহজ মানসিক মডেল. - ডিভাইসের আকার জুড়ে সহজে স্কেলিং করার জন্য, ব্লক উপাদানগুলি
rems-এর জন্যmargins ব্যবহার করা উচিত। - -সম্পর্কিত বৈশিষ্ট্যের ঘোষণা
fontন্যূনতম রাখুন,inheritযখনই সম্ভব ব্যবহার করুন।
CSS ভেরিয়েবল
v5.2.0 এ যোগ করা হয়েছেv5.1.1 এর সাথে, আমরা অন্তর্ভুক্ত করার জন্য আমাদের সমস্ত CSS বান্ডেল ( , , এবং সহ ) @importজুড়ে আমাদের প্রয়োজনীয় গুলিকে প্রমিত করেছি । এটি সমস্ত বান্ডেলে লেভেল CSS ভেরিয়েবল যোগ করে, সেই বান্ডেলে কতগুলি ব্যবহার করা হোক না কেন। শেষ পর্যন্ত বুটস্ট্র্যাপ 5 সময়ের সাথে সাথে আরও বেশি CSS ভেরিয়েবল যোগ করা অব্যাহত রাখবে, যাতে সবসময় Sass পুনরায় কম্পাইল করার প্রয়োজন ছাড়াই আরও রিয়েল-টাইম কাস্টমাইজেশন প্রদান করা যায়। আমাদের পন্থা হল আমাদের সোর্স Sass ভেরিয়েবলগুলি নেওয়া এবং সেগুলিকে CSS ভেরিয়েবলে রূপান্তর করা। এইভাবে, আপনি যদি CSS ভেরিয়েবল ব্যবহার না করেন, তবুও আপনার কাছে Sass-এর সমস্ত ক্ষমতা আছে। এটি এখনও প্রক্রিয়াধীন এবং সম্পূর্ণরূপে বাস্তবায়নে সময় লাগবে৷bootstrap.cssbootstrap-reboot.cssbootstrap-grid.css_root.scss:root
উদাহরণস্বরূপ, সাধারণ শৈলীগুলির :rootজন্য এই CSS ভেরিয়েবলগুলি বিবেচনা করুন:<body>
@if $font-size-root != null {
--#{$prefix}root-font-size: #{$font-size-root};
}
--#{$prefix}body-font-family: #{$font-family-base};
@include rfs($font-size-base, --#{$prefix}body-font-size);
--#{$prefix}body-font-weight: #{$font-weight-base};
--#{$prefix}body-line-height: #{$line-height-base};
--#{$prefix}body-color: #{$body-color};
@if $body-text-align != null {
--#{$prefix}body-text-align: #{$body-text-align};
}
--#{$prefix}body-bg: #{$body-bg};
অনুশীলনে, সেই ভেরিয়েবলগুলি তারপরে রিবুটে প্রয়োগ করা হয়:
body {
margin: 0; // 1
font-family: var(--#{$prefix}body-font-family);
@include font-size(var(--#{$prefix}body-font-size));
font-weight: var(--#{$prefix}body-font-weight);
line-height: var(--#{$prefix}body-line-height);
color: var(--#{$prefix}body-color);
text-align: var(--#{$prefix}body-text-align);
background-color: var(--#{$prefix}body-bg); // 2
-webkit-text-size-adjust: 100%; // 3
-webkit-tap-highlight-color: rgba($black, 0); // 4
}
যা আপনাকে রিয়েল-টাইম কাস্টমাইজেশন করতে দেয় যদিও আপনি চান:
<body style="--bs-body-color: #333;">
<!-- ... -->
</body>
পৃষ্ঠা ডিফল্ট
আরও ভাল পৃষ্ঠা-ব্যাপী ডিফল্ট প্রদান করতে উপাদান <html>এবং <body>উপাদান আপডেট করা হয়। আরো নির্দিষ্টভাবে:
- বিশ্বব্যাপী
box-sizingপ্রতিটি উপাদানের উপর সেট করা আছে—সহ*::beforeএবং*::after, থেকেborder-box। এটি নিশ্চিত করে যে প্যাডিং বা সীমানার কারণে উপাদানটির ঘোষিত প্রস্থ কখনই অতিক্রম করবে না।- তে কোন বেস
font-sizeঘোষণা করা হয় না<html>, তবে16pxধরে নেওয়া হয় (ব্রাউজার ডিফল্ট)। ব্যবহারকারীর পছন্দগুলিকে সম্মান করে এবং আরও অ্যাক্সেসযোগ্য পদ্ধতি নিশ্চিত করার সময় মিডিয়া প্রশ্নের মাধ্যমে সহজ প্রতিক্রিয়াশীল টাইপ-স্কেলিংয়ের জন্যfont-size: 1remপ্রয়োগ করা হয় ।<body>এই ব্রাউজার ডিফল্ট পরিবর্তনশীল পরিবর্তন করে ওভাররাইড করা যেতে পারে$font-size-root.
- তে কোন বেস
- এছাড়াও
<body>একটি বিশ্বব্যাপীfont-family,font-weight,line-height, এবং সেট করেcolor। ফন্টের অসঙ্গতি রোধ করার জন্য এটি কিছু ফর্ম উপাদান দ্বারা উত্তরাধিকারসূত্রে প্রাপ্ত হয়। - নিরাপত্তার জন্য,
<body>একটি ঘোষণা করেছেbackground-color, ডিফল্ট করেছে#fff।
নেটিভ ফন্ট স্ট্যাক
বুটস্ট্র্যাপ প্রতিটি ডিভাইস এবং OS-এ সর্বোত্তম পাঠ্য রেন্ডারিংয়ের জন্য একটি "নেটিভ ফন্ট স্ট্যাক" বা "সিস্টেম ফন্ট স্ট্যাক" ব্যবহার করে। এই সিস্টেম ফন্টগুলি বিশেষভাবে আজকের ডিভাইসগুলিকে মাথায় রেখে ডিজাইন করা হয়েছে, স্ক্রীনে উন্নত রেন্ডারিং, পরিবর্তনশীল ফন্ট সমর্থন এবং আরও অনেক কিছু। এই স্ম্যাশিং ম্যাগাজিন নিবন্ধে নেটিভ ফন্ট স্ট্যাক সম্পর্কে আরও পড়ুন ।
$font-family-sans-serif:
// Cross-platform generic font family (default user interface font)
system-ui,
// Safari for macOS and iOS (San Francisco)
-apple-system,
// Windows
"Segoe UI",
// Android
Roboto,
// older macOS and iOS
"Helvetica Neue"
// Linux
"Noto Sans",
"Liberation Sans",
// Basic web fallback
Arial,
// Sans serif fallback
sans-serif,
// Emoji fonts
"Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;
মনে রাখবেন যেহেতু ফন্ট স্ট্যাকে ইমোজি ফন্ট অন্তর্ভুক্ত রয়েছে, তাই অনেক সাধারণ প্রতীক/ডিংব্যাট ইউনিকোড অক্ষরগুলি বহু রঙের ছবি হিসাবে রেন্ডার করা হবে। ব্রাউজার/প্ল্যাটফর্মের নেটিভ ইমোজি ফন্টে ব্যবহৃত শৈলীর উপর নির্ভর করে তাদের চেহারা পরিবর্তিত হবে এবং তারা কোন CSS colorশৈলী দ্বারা প্রভাবিত হবে না।
এটি বুটস্ট্র্যাপ জুড়ে বিশ্বব্যাপী স্বয়ংক্রিয়ভাবে উত্তরাধিকার সূত্রে প্রাপ্ত এবং font-familyপ্রয়োগ করা হয় । <body>গ্লোবাল পরিবর্তন করতে , বুটস্ট্র্যাপ font-familyআপডেট এবং পুনরায় কম্পাইল করুন।$font-family-base
শিরোনাম এবং অনুচ্ছেদ
সমস্ত শিরোনাম উপাদান—উদাহরণস্বরূপ, <h1>—এবং <p>তাদের margin-topসরানোর জন্য পুনরায় সেট করা হয়েছে। শিরোনাম যোগ করা হয়েছে এবং সহজ ব্যবধান জন্য margin-bottom: .5remঅনুচ্ছেদ .margin-bottom: 1rem
| শিরোনাম | উদাহরণ |
|---|---|
<h1></h1> |
h1. বুটস্ট্র্যাপ শিরোনাম |
<h2></h2> |
h2. বুটস্ট্র্যাপ শিরোনাম |
<h3></h3> |
h3. বুটস্ট্র্যাপ শিরোনাম |
<h4></h4> |
h4. বুটস্ট্র্যাপ শিরোনাম |
<h5></h5> |
h5. বুটস্ট্র্যাপ শিরোনাম |
<h6></h6> |
h6. বুটস্ট্র্যাপ শিরোনাম |
অনুভূমিক নিয়ম
<hr>উপাদান সরলীকৃত করা হয়েছে . ব্রাউজার ডিফল্টের মতো, <hr>s এর মাধ্যমে স্টাইল করা হয় border-top, একটি ডিফল্ট থাকে এবং স্বয়ংক্রিয়ভাবে তাদের এর মাধ্যমে opacity: .25উত্তরাধিকারী হয় , যখন পিতামাতার মাধ্যমে সেট করা হয়। এগুলি পাঠ্য, সীমানা এবং অস্বচ্ছতা ইউটিলিটিগুলির সাথে সংশোধন করা যেতে পারে।border-colorcolorcolor
<hr>
<div class="text-success">
<hr>
</div>
<hr class="border border-danger border-2 opacity-50">
<hr class="border border-primary border-3 opacity-75">
তালিকা
সমস্ত তালিকা — <ul>, <ol>, এবং <dl>— তাদের margin-topসরানো হয়েছে এবং একটি margin-bottom: 1rem. নেস্টেড তালিকার কোন নেই margin-bottom। padding-leftআমরা চালু <ul>এবং <ol>উপাদান রিসেট করেছি .
- সমস্ত তালিকা তাদের শীর্ষ মার্জিন সরানো হয়েছে
- এবং তাদের নিম্ন মার্জিন স্বাভাবিক করা হয়েছে
- নেস্টেড তালিকার নিচের মার্জিন নেই
- এই ভাবে তারা একটি আরো এমনকি চেহারা আছে
- বিশেষ করে যখন আরও তালিকা আইটেম দ্বারা অনুসরণ করা হয়
- বাম প্যাডিংও রিসেট করা হয়েছে
- এখানে একটি আদেশ তালিকা
- কয়েকটি তালিকা আইটেম সঙ্গে
- এটি একই সামগ্রিক চেহারা আছে
- আগের মতোই সাজানো তালিকা
সহজ স্টাইলিং, স্পষ্ট শ্রেণিবিন্যাস এবং আরও ভাল ব্যবধানের জন্য, বর্ণনা তালিকাগুলি আপডেট করেছে margin। <dd>s রিসেট margin-leftকরুন 0এবং যোগ করুন margin-bottom: .5rem। <dt>s গাঢ় হয় .
- বর্ণনা তালিকা
- একটি বর্ণনা তালিকা শর্তাবলী সংজ্ঞায়িত করার জন্য উপযুক্ত।
- মেয়াদ
- শব্দের জন্য সংজ্ঞা।
- একই শব্দের জন্য একটি দ্বিতীয় সংজ্ঞা।
- আরেকটি পদ
- এই অন্য পদের জন্য সংজ্ঞা.
ইনলাইন কোড
কোডের ইনলাইন স্নিপেটগুলি দিয়ে মোড়ানো <code>। এইচটিএমএল কোণ বন্ধনী এড়ানো নিশ্চিত করুন।
<section>ইনলাইন হিসাবে আবৃত করা উচিত.
For example, <code><section></code> should be wrapped as inline.
কোড ব্লক
<pre>কোডের একাধিক লাইনের জন্য s ব্যবহার করুন । আবার, সঠিক রেন্ডারিংয়ের জন্য কোডে যেকোন অ্যাঙ্গেল ব্র্যাকেট এড়িয়ে যেতে ভুলবেন না। উপাদানটিকে <pre>অপসারণ করতে margin-topএবং এর জন্য remইউনিটগুলি ব্যবহার করতে পুনরায় সেট করা হয়েছে margin-bottom।
<p>Sample text here...</p>
<p>And another line of sample text here...</p>
<pre><code><p>Sample text here...</p>
<p>And another line of sample text here...</p>
</code></pre>
ভেরিয়েবল
ভেরিয়েবল নির্দেশ করার জন্য <var>ট্যাগ ব্যবহার করুন।
<var>y</var> = <var>m</var><var>x</var> + <var>b</var>
ব্যবহারকারীর ইনপুট
<kbd>ইনপুট নির্দেশ করতে ব্যবহার করুন যা সাধারণত কীবোর্ডের মাধ্যমে প্রবেশ করা হয়।
সেটিংস সম্পাদনা করতে, টিপুন ctrl + ,
To switch directories, type <kbd>cd</kbd> followed by the name of the directory.<br>
To edit settings, press <kbd><kbd>ctrl</kbd> + <kbd>,</kbd></kbd>
নমুনা আউটপুট
একটি প্রোগ্রাম থেকে নমুনা আউটপুট নির্দেশ করার জন্য <samp>ট্যাগ ব্যবহার করুন.
<samp>This text is meant to be treated as sample output from a computer program.</samp>
টেবিল
টেবিলগুলিকে স্টাইল s-এর সাথে সামান্য সামঞ্জস্য করা হয় <caption>, সীমানা ভেঙে দেওয়া হয় এবং text-alignসর্বত্র সামঞ্জস্যপূর্ণ নিশ্চিত করা হয়। বর্ডার, প্যাডিং এবং আরও অনেক কিছুর জন্য অতিরিক্ত পরিবর্তন ক্লাসের .tableসাথে আসে ।
| টেবিল শিরোনাম | টেবিল শিরোনাম | টেবিল শিরোনাম | টেবিল শিরোনাম |
|---|---|---|---|
| টেবিল সেল | টেবিল সেল | টেবিল সেল | টেবিল সেল |
| টেবিল সেল | টেবিল সেল | টেবিল সেল | টেবিল সেল |
| টেবিল সেল | টেবিল সেল | টেবিল সেল | টেবিল সেল |
<table>
<caption>
This is an example table, and this is its caption to describe the contents.
</caption>
<thead>
<tr>
<th>Table heading</th>
<th>Table heading</th>
<th>Table heading</th>
<th>Table heading</th>
</tr>
</thead>
<tbody>
<tr>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
</tr>
<tr>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
</tr>
<tr>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
<td>Table cell</td>
</tr>
</tbody>
</table>
ফর্ম
সহজ বেস শৈলীর জন্য বিভিন্ন ফর্ম উপাদান রিবুট করা হয়েছে। এখানে সবচেয়ে উল্লেখযোগ্য কিছু পরিবর্তন রয়েছে:
<fieldset>s-এর কোনো সীমানা, প্যাডিং বা মার্জিন নেই তাই এগুলি সহজেই পৃথক ইনপুট বা ইনপুটগুলির গ্রুপের জন্য মোড়ক হিসাবে ব্যবহার করা যেতে পারে।<legend>s, ফিল্ডসেটের মতো, বিভিন্ন ধরণের শিরোনাম হিসাবে প্রদর্শিত হওয়ার জন্য পুনরায় স্টাইল করা হয়েছে।<label>s প্রয়োগdisplay: inline-blockকরার অনুমতি দেওয়ার জন্য সেট করা হয়েছে।margin<input>s,<select>s,<textarea>s, এবং<button>s বেশিরভাগই Normalize দ্বারা সম্বোধন করা হয়, কিন্তু Reboot তাদেরmarginএবং সেটগুলিকেও সরিয়ে দেয়line-height: inherit।<textarea>অনুভূমিক আকার পরিবর্তন প্রায়ই "ব্রেক" পৃষ্ঠা বিন্যাস হিসাবে s শুধুমাত্র উল্লম্বভাবে রিসাইজ করার জন্য পরিবর্তন করা হয়।<button>s এবং<input>বোতাম উপাদান আছেcursor: pointerযখন:not(:disabled).
এই পরিবর্তন, এবং আরো, নীচে প্রদর্শিত হয়.
তারিখ এবং রঙ ইনপুট সমর্থন
মনে রাখবেন ডেট ইনপুটগুলি সাফারি নামে সমস্ত ব্রাউজার দ্বারা সম্পূর্ণরূপে সমর্থিত নয়৷
বোতামে পয়েন্টার
role="button"রিবুটে ডিফল্ট কার্সার পরিবর্তন করার জন্য একটি বর্ধিতকরণ অন্তর্ভুক্ত রয়েছে pointer৷ উপাদানগুলি ইন্টারেক্টিভ নির্দেশ করতে সাহায্য করার জন্য উপাদানগুলিতে এই বৈশিষ্ট্যটি যুক্ত করুন৷ এই ভূমিকাটি <button>উপাদানগুলির জন্য প্রয়োজনীয় নয়, যা তাদের নিজস্ব cursorপরিবর্তন পায়।
<span role="button" tabindex="0">Non-button element button</span>
বিবিধ উপাদান
ঠিকানা
ব্রাউজার ডিফল্ট থেকে তে <address>রিসেট করতে উপাদানটি আপডেট করা হয়েছে । এছাড়াও এখন উত্তরাধিকারসূত্রে প্রাপ্ত, এবং যোগ করা হয়েছে। s হল নিকটতম পূর্বপুরুষের (বা কাজের একটি সম্পূর্ণ অংশ) জন্য যোগাযোগের তথ্য উপস্থাপন করার জন্য। এর সাথে লাইন শেষ করে বিন্যাস সংরক্ষণ করুন ।font-styleitalicnormalline-heightmargin-bottom: 1rem<address><br>
1355 Market St, Suite 900
San Francisco, CA 94103
P: (123) 456-7890 পুরো নাম
[email protected]
ব্লককোট
ব্লককোটগুলির ডিফল্ট marginহল 1em 40px, তাই আমরা 0 0 1remঅন্যান্য উপাদানগুলির সাথে আরও সামঞ্জস্যপূর্ণ কিছুর জন্য এটি পুনরায় সেট করি।
একটি সুপরিচিত উদ্ধৃতি, একটি ব্লককোট উপাদানের মধ্যে রয়েছে।
উৎস শিরোনামে বিখ্যাত কেউ
ইনলাইন উপাদান
অনুচ্ছেদ পাঠ্যের <abbr>মধ্যে এটিকে আলাদা করার জন্য উপাদানটি মৌলিক স্টাইলিং গ্রহণ করে।
সারসংক্ষেপ
সারাংশে ডিফল্ট cursorহল text, তাই আমরা এটিকে রিসেট করি যাতে pointerবোঝাতে হয় যে উপাদানটির সাথে এটিতে ক্লিক করে ইন্টারঅ্যাক্ট করা যেতে পারে।
কিছু বিবরণ
বিস্তারিত সম্পর্কে আরো তথ্য.
এমনকি আরো বিস্তারিত
এখানে বিস্তারিত সম্পর্কে আরো বিস্তারিত আছে.
HTML5 [hidden]বৈশিষ্ট্য
HTML5 নামের একটি নতুন গ্লোবাল অ্যাট্রিবিউট[hidden]display: none যোগ করে, যা ডিফল্ট হিসেবে স্টাইল করা হয়। PureCSS থেকে একটি ধারণা ধার করে , আমরা এই ডিফল্টটিকে ভুলবশত ওভাররাইড হওয়া থেকে [hidden] { display: none !important; }রক্ষা করতে সাহায্য করার মাধ্যমে উন্নতি করি।display
<input type="text" hidden>
jQuery অসঙ্গতি
[hidden]$(...).hide()jQuery এর এবং $(...).show()পদ্ধতির সাথে সামঞ্জস্যপূর্ণ নয় । অতএব, আমরা বর্তমানে উপাদানগুলির [hidden]পরিচালনার জন্য অন্যান্য কৌশলগুলির উপর বিশেষভাবে সমর্থন করি না।display
শুধুমাত্র একটি উপাদানের দৃশ্যমানতা টগল করতে, যার অর্থ এটি displayপরিবর্তন করা হয়নি এবং উপাদানটি এখনও নথির প্রবাহকে প্রভাবিত করতে পারে, পরিবর্তে ক্লাসটি ব্যবহার করুন.invisible ।