सस्स
चर, नक्शे, मिक्सिन, ते फंक्शनें दा फायदा लैने आस्तै साढ़ी स्रोत Sass फाइलें दा उपयोग करो तां जे तुसेंगी तेज़ी कन्नै बनाने ते अपने प्रोजेक्ट गी अनुकूलित करने च मदद मिलै।
चर, नक्शे, मिक्सिन, ते होर मते दा फायदा लैने आस्तै साढ़ी स्रोत Sass फाइलें दा उपयोग करो।
फाइल दा ढांचा
जदूं बी होई सकै, बूटस्ट्रैप दी कोर फाइलें गी संशोधित करने थमां बचो. सस्स आस्तै, इसदा मतलब ऐ जे अपनी खुद दी स्टाइलशीट बनाओ जेह् ड़ी बूटस्ट्रैप गी आयात करदी ऐ तां जे तुस इसगी संशोधित ते विस्तार करी सकदे ओ. एह् मनदे होई जे तुस npm जनेह् पैकेज प्रबंधक दा इस्तेमाल करा करदे ओ, तुंदे कोल इक फाइल संरचना होग जेह् ड़ी इस चाल्ली दिक्खदी ऐ:
your-project/
├── scss
│ └── custom.scss
└── node_modules/
└── bootstrap
├── js
└── scss
जेकर तुसें साढ़ी स्रोत फाइलें गी डाउनलोड कीता ऐ ते पैकेज प्रबंधक दा इस्तेमाल नेईं करा करदे ओ तां तुस उस संरचना दे समान किश मैन्युअल रूप कन्नै बनाना चांह् दे ओ, बूटस्ट्रैप दी स्रोत फाइलें गी अपने थमां बक्ख रक्खदे होई.
your-project/
├── scss
│ └── custom.scss
└── bootstrap/
├── js
└── scss
आयात करना
अपने custom.scss
, च तुस बूटस्ट्रैप दी स्रोत Sass फाइलें गी आयात करगेओ. तुंदे कोल दो विकल्प न: बूटस्ट्रैप दे सारे गी शामल करो, जां तुसेंगी लोड़चदे हिस्से चुनो. अस बाद आह् ली गी प्रोत्साहित करने आं , हालांकि इस गल्लै दा ध्यान रक्खो जे साढ़े घटकें च किश जरूरतें ते निर्भरताएं न । तुसेंगी साढ़े प्लगइन्स आस्तै किश जावास्क्रिप्ट बी शामल करने दी लोड़ होग।
// Custom.scss
// Option A: Include all of Bootstrap
// Include any default variable overrides here (though functions won't be available)
@import "../node_modules/bootstrap/scss/bootstrap";
// Then add additional custom code here
// Custom.scss
// Option B: Include parts of Bootstrap
// 1. Include functions first (so you can manipulate colors, SVGs, calc, etc)
@import "../node_modules/bootstrap/scss/functions";
// 2. Include any default variable overrides here
// 3. Include remainder of required Bootstrap stylesheets
@import "../node_modules/bootstrap/scss/variables";
// 4. Include any default map overrides here
// 5. Include remainder of required parts
@import "../node_modules/bootstrap/scss/maps";
@import "../node_modules/bootstrap/scss/mixins";
@import "../node_modules/bootstrap/scss/root";
// 6. Optionally include any other parts as needed
@import "../node_modules/bootstrap/scss/utilities";
@import "../node_modules/bootstrap/scss/reboot";
@import "../node_modules/bootstrap/scss/type";
@import "../node_modules/bootstrap/scss/images";
@import "../node_modules/bootstrap/scss/containers";
@import "../node_modules/bootstrap/scss/grid";
@import "../node_modules/bootstrap/scss/helpers";
// 7. Optionally include utilities API last to generate classes based on the Sass map in `_utilities.scss`
@import "../node_modules/bootstrap/scss/utilities/api";
// 8. Add additional custom code here
उस सेटअप गी जगह च रखदे होई, तुस अपने custom.scss
. // Optional
तुस जरूरत मताबक खंड दे हेठ बूटस्ट्रैप दे हिस्से गी बी जोड़ना शुरू करी सकदे ओ । bootstrap.scss
अस सुझाऽ दिन्दे आं जे साढ़ी फाइल थमां पूरा आयात ढेर गी अपने शुरूआती बिंदु दे रूप च इस्तेमाल करो.
चर डिफ़ॉल्ट होंदे न
बूटस्ट्रैप च हर Sass चर च !default
फ्लैग शामल ऐ जेह् ड़ा तुसेंगी बूटस्ट्रैप दे स्रोत कोड गी संशोधित कीते बगैर अपने खुद दे Sass च चर दे डिफाल्ट वैल्यू गी ओवरराइड करने दी इजाजत दिंदा ऐ. जरूरत मताबक चर गी कापी ते पेस्ट करो, उंदे मूल्यें गी संशोधित करो, ते !default
झंडा हटाओ. जेकर कोई चर पैह् ले थमां गै असाइन कीता गेदा ऐ , तां उसगी बूटस्ट्रैप च डिफाल्ट वैल्यूएं आसेआ दुबारा असाइन नेईं कीता जाग.
तुसें गी बूटस्ट्रैप दे चर दी पूरी सूची च मिलग scss/_variables.scss
. किश चर गी सेट कीता गेदा ऐ null
, एह् चर गुण गी आउटपुट नेईं करदे जदूं तकर एह् तुंदे कॉन्फ़िगरेशन च ओवरराइड नेईं कीते जंदे.
चर ओवरराइड साढ़े फंक्शनें गी आयात करने दे बाद औना चाहिदा ऐ, पर बाकी आयातें शा पैह् ले।
इत्थै इक उदाहरण ऐ जेह् ड़ा npm दे राहें बूटस्ट्रैप आयात ते संकलन करदे बेल्लै background-color
ते color
आस्तै बदलदा ऐ:<body>
// Required
@import "../node_modules/bootstrap/scss/functions";
// Default variable overrides
$body-bg: #000;
$body-color: #111;
// Required
@import "../node_modules/bootstrap/scss/variables";
@import "../node_modules/bootstrap/scss/maps";
@import "../node_modules/bootstrap/scss/mixins";
@import "../node_modules/bootstrap/scss/root";
// Optional Bootstrap components here
@import "../node_modules/bootstrap/scss/reboot";
@import "../node_modules/bootstrap/scss/type";
// etc
बूटस्ट्रैप च कुसै बी चर आस्तै जरूरी मताबक दोहराओ, जिंदे च हेठ दित्ते गेदे वैश्विक विकल्प बी शामल न.
नक्शे ते लूप
बूटस्ट्रैप च मुट्ठी भर Sass नक्शे, कुंजी मूल्य जोड़े शामल न जेह् ड़े सरबंधत CSS दे परिवारें गी पैदा करना सखल्ला बनांदे न। अस अपने रंगें, ग्रिड ब्रेकपॉइंटें, ते होर मते सारें लेई Sass नक्शे दा इस्तेमाल करदे आं। जि'यां Sass चर, सारे Sass नक्शे च !default
झंडा शामल ऐ ते ओवरराइड ते विस्तार कीता जाई सकदा ऐ।
साढ़े किश सास नक्शे डिफ़ॉल्ट रूप कन्नै खाली च मर्ज कीते गेदे न। एह् कुसै दित्ते गेदे सस नक्शे गी आसानी कन्नै विस्तार करने दी अनुमति देने लेई कीता जंदा ऐ, पर एह्दे कन्नै नक्शे थमां आइटमें गी हटाने गी थोड़ा होर मुश्कल बनाने दी कीमत पर औंदा ऐ ।
नक्शा संशोधित करो
$theme-colors
नक्शे च सारे चर गी स्टैंडअलोन चर दे रूप च परिभाशत कीता गेआ ऐ। साढ़े $theme-colors
नक्शे च इक मौजूदा रंग गी संशोधित करने आस्तै, अपनी कस्टम Sass फाइल च निम्नलिखित जोड़ो:
$primary: #0074d9;
$danger: #ff4136;
बाद च, एह् चर बूटस्ट्रैप दे $theme-colors
नक्शे च सेट कीते जंदे न:
$theme-colors: (
"primary": $primary,
"danger": $danger
);
नक्शे पर जोड़ो
$theme-colors
अपने कस्टम मूल्यें कन्नै इक नमां Sass नक्शा बनाइयै ते इसगी मूल नक्शे कन्नै मर्ज करियै , जां कुसै होर नक्शे च नमें रंग जोड़ो . $custom-colors
इस मामले च, अस इक नमां नक्शा बनागे ते इसगी $theme-colors
.
// Create your own map
$custom-colors: (
"custom-color": #900
);
// Merge the maps
$theme-colors: map-merge($theme-colors, $custom-colors);
नक्शे से हटा दे
$theme-colors
, जां कुसै होर नक्शे थमां रंगें गी हटाने लेई , इस्तेमाल करो map-remove
. ध्यान रक्खो तुसें गी $theme-colors
साढ़ी जरूरतें दे बीच इसदी परिभाषा दे ठीक बाद च variables
ते इसदे इस्तेमाल थमां पैह्ले च सम्मिलित करना होग maps
:
// Required
@import "../node_modules/bootstrap/scss/functions";
@import "../node_modules/bootstrap/scss/variables";
$theme-colors: map-remove($theme-colors, "info", "light", "dark");
@import "../node_modules/bootstrap/scss/maps";
@import "../node_modules/bootstrap/scss/mixins";
@import "../node_modules/bootstrap/scss/root";
// Optional
@import "../node_modules/bootstrap/scss/reboot";
@import "../node_modules/bootstrap/scss/type";
// etc
जरूरी कुंजी
बूटस्ट्रैप Sass नक्शे दे अंदर किश विशिष्ट कुंजियें दी मौजूदगी गी मनदा ऐ जिऱयां अस इन्हें दा इस्तेमाल करदे आं ते अपने आपै गी विस्तार दिंदे आं। जि’यां-जि’यां तुस शामल नक्शे गी अनुकूलित करदे ओ, तुसेंगी त्रुट्टी दा सामना करना पौंदा ऐ जित्थै कुसै विशिष्ट Sass नक्शे दी कुंजी दा इस्तेमाल कीता जा करदा ऐ।
मसाल आस्तै, अस लिंक, बटन, ते फार्म स्टेटें आस्तै primary
, success
, ते danger
कुंजियें दा इस्तेमाल करदे आं। $theme-colors
इनें कुंजियें दे मूल्यें गी बदलने कन्नै कोई मुद्दा नेईं पेश करना चाहिदा, पर उनेंगी हटाने कन्नै Sass संकलन मुद्दे पैदा होई सकदे न. इनें दृष्टांतें च, तुसेंगी उनें मूल्यें दा इस्तेमाल करने आह् ले सस कोड गी संशोधित करने दी लोड़ होग.
फंक्शन करदा ऐ
रंगें
साढ़े कोल जेह् ड़े सास नक्शे न उंदे बगल च , थीम रंगें गी स्टैंडअलोन चर दे रूप च बी इस्तेमाल कीता जाई सकदा ऐ, जि’यां $primary
.
.custom-element {
color: $gray-100;
background-color: $dark;
}
तुस बूटस्ट्रैप tint-color()
ते shade-color()
फंक्शनें कन्नै रंगें गी हल्का जां गहरा करी सकदे ओ। एह् फंक्शन काले जां सफेद कन्नै रंगें गी मिलांगन, सस्स दे मूल lighten()
ते darken()
फंक्शनें दे विपरीत जेह् ड़े हल्केपन गी इक निश्चित मात्रा कन्नै बदली देङन, जेह् ड़े अक्सर वांछित प्रभाव नेईं पांदे न।
// Tint a color: mix a color with white
@function tint-color($color, $weight) {
@return mix(white, $color, $weight);
}
// Shade a color: mix a color with black
@function shade-color($color, $weight) {
@return mix(black, $color, $weight);
}
// Shade the color if the weight is positive, else tint it
@function shift-color($color, $weight) {
@return if($weight > 0, shade-color($color, $weight), tint-color($color, -$weight));
}
व्यवहार च, तुस फंक्शन गी कॉल करगेओ ते रंग ते वजन पैरामीटर च पास करगेओ।
.custom-element {
color: tint-color($primary, 10%);
}
.custom-element-2 {
color: shade-color($danger, 30%);
}
रंग विपरीत
वेब सामग्री एक्सेसबिलिटी गाइडलाइन (WCAG) विपरीत जरूरतें गी पूरा करने आस्तै , लेखकें गी 4.5:1 दा घट्ट शा घट्ट पाठ रंग विपरीत ते 3:1 दा घट्ट शा घट्ट गैर-पाठ रंग विपरीत प्रदान करना होग , जिस च मते सारे अपवाद न।
इस च मदद करने आस्तै, असें color-contrast
बूटस्ट्रैप च फंक्शन शामल कीता। एह् निर्दिश्ट आधार रंग दे आधार उप्पर इक प्रकाश ( ), काला ( ) जां काला ( ) विपरीत रंग गी स्वतः वापस करने आस्तै इक रंग स्पेस च सापेक्ष चमक दे आधार उप्पर कंट्रास्ट थ्रेशोल्ड दी गणना आस्तै WCAG कंट्रास्ट रेशियो एल्गोरिथ्म दा उपयोग करदा ऐ। एह् फंक्शन खास करियै मिक्सिन जां लूप आस्तै उपयोगी ऐ जित्थै तुस मते सारे वर्गें गी पैदा करा करदे ओ.sRGB
#fff
#212529
#000
मसाल आस्तै, साढ़े $theme-colors
नक्शे थमां रंग नमूनें गी पैदा करने आस्तै:
@each $color, $value in $theme-colors {
.swatch-#{$color} {
color: color-contrast($value);
}
}
इसदा इस्तेमाल इक बारी दी कंट्रास्ट जरूरतें लेई बी कीता जाई सकदा ऐ:
.custom-element {
color: color-contrast(#000); // returns `color: #fff`
}
तुस साढ़े रंग नक्शा फंक्शनें कन्नै इक आधार रंग बी निर्दिश्ट करी सकदे ओ:
.custom-element {
color: color-contrast($dark); // returns `color: #fff`
}
एसवीजी से बच जाओ
अस escape-svg
फंक्शन दा इस्तेमाल करदे आं <
, >
ते #
एसवीजी बैकग्राउंड छवियें आस्तै वर्णें गी बचने आस्तै। फंक्शन दा उपयोग करदे बेल्लै escape-svg
डेटा यूआरआई गी उद्धृत करना जरूरी ऐ।
जोड़ना ते घटाना फंक्शन
अस सीएसएस फंक्शन गी लपेटने लेई add
ते फंक्शनें दा इस्तेमाल करदे आं । इनें फंक्शनें दा प्राथमिक मकसद ऐ जे जिसलै इक "यूनिटलेस" मूल्य गी इक अभिव्यक्ति च पास कीता जंदा ऐ तां त्रुटिएं थमां बचना ऐ। जियां अभिव्यक्ति गणितीय रूप कन्नै सही होने दे बावजूद, सारे ब्राउज़रें च इक त्रुटि वापस करग.subtract
calc
0
calc
calc(10px - 0)
उदाहरण जित्थै कैल्क मान्य ऐ :
$border-radius: .25rem;
$border-width: 1px;
.element {
// Output calc(.25rem - 1px) is valid
border-radius: calc($border-radius - $border-width);
}
.element {
// Output the same calc(.25rem - 1px) as above
border-radius: subtract($border-radius, $border-width);
}
उदाहरण जित्थै कैल्क अमान्य ऐ :
$border-radius: .25rem;
$border-width: 0;
.element {
// Output calc(.25rem - 0) is invalid
border-radius: calc($border-radius - $border-width);
}
.element {
// Output .25rem
border-radius: subtract($border-radius, $border-width);
}
मिक्सिन
साढ़ी scss/mixins/
डायरेक्टरी च इक टन मिक्सिन ऐ जेह् ड़े बूटस्ट्रैप दे हिस्सें गी पावर दिंदे न ते तुंदे अपने प्रोजेक्ट च बी इसदा इस्तेमाल कीता जाई सकदा ऐ।
रंग योजनाएं
मीडिया क्वेरी आस्तै इक आशुलिपि मिक्सिन , , ते कस्टम रंग योजनाएं prefers-color-scheme
आस्तै समर्थन कन्नै उपलब्ध ऐ .light
dark
@mixin color-scheme($name) {
@media (prefers-color-scheme: #{$name}) {
@content;
}
}
.custom-element {
@include color-scheme(dark) {
// Insert dark mode styles here
}
@include color-scheme(custom-named-scheme) {
// Insert custom color scheme styles here
}
}