Source

தீமிங் பூட்ஸ்டார்ப்

எளிதான தீமிங் மற்றும் கூறு மாற்றங்களுக்காக உலகளாவிய பாணி விருப்பத்தேர்வுகளுக்காக எங்களின் புதிய உள்ளமைக்கப்பட்ட சாஸ் மாறிகள் மூலம் பூட்ஸ்டார்ப் 4 ஐத் தனிப்பயனாக்குங்கள்.

அறிமுகம்

பூட்ஸ்டார்ப் 3 இல், தீமிங் பெரும்பாலும் குறைவான மாறுதல்கள், தனிப்பயன் CSS மற்றும் எங்கள் distகோப்புகளில் நாங்கள் சேர்த்த ஒரு தனி தீம் ஸ்டைல்ஷீட் ஆகியவற்றால் இயக்கப்படுகிறது. சில முயற்சிகள் மூலம், முக்கிய கோப்புகளைத் தொடாமல் பூட்ஸ்டார்ப் 3 இன் தோற்றத்தை முழுமையாக மறுவடிவமைப்பு செய்யலாம். பூட்ஸ்டார்ப் 4 ஒரு பழக்கமான, ஆனால் சற்று வித்தியாசமான அணுகுமுறையை வழங்குகிறது.

இப்போது, ​​சாஸ் மாறிகள், சாஸ் வரைபடங்கள் மற்றும் தனிப்பயன் CSS மூலம் தீமிங் நிறைவேற்றப்படுகிறது. மேலும் அர்ப்பணிக்கப்பட்ட தீம் நடை தாள் இல்லை; அதற்கு பதிலாக, சாய்வுகள், நிழல்கள் மற்றும் பலவற்றைச் சேர்க்க நீங்கள் உள்ளமைக்கப்பட்ட தீமை இயக்கலாம்.

சாஸ்

மாறிகள், வரைபடங்கள், மிக்சின்கள் மற்றும் பலவற்றைப் பயன்படுத்திக் கொள்ள எங்கள் மூல சாஸ் கோப்புகளைப் பயன்படுத்தவும். எங்கள் கட்டமைப்பில், உலாவி ரவுண்டிங்கில் சிக்கல்களைத் தடுக்க, சாஸ் ரவுண்டிங் துல்லியத்தை 6 ஆக (இயல்புநிலையாக இது 5) அதிகரித்துள்ளோம்.

கோப்பு அமைப்பு

முடிந்தவரை, பூட்ஸ்டார்ப்பின் முக்கிய கோப்புகளை மாற்றுவதைத் தவிர்க்கவும். சாஸைப் பொறுத்தவரை, பூட்ஸ்டார்ப்பை இறக்குமதி செய்யும் உங்கள் சொந்த ஸ்டைல்ஷீட்டை உருவாக்குவதன் மூலம் அதை நீங்கள் மாற்றியமைத்து நீட்டிக்க முடியும். நீங்கள் npm போன்ற தொகுப்பு மேலாளரைப் பயன்படுத்துகிறீர்கள் என்று வைத்துக் கொண்டால், இது போன்ற ஒரு கோப்பு அமைப்பு உங்களிடம் இருக்கும்:

your-project/
├── scss
│   └── custom.scss
└── node_modules/
    └── bootstrap
        ├── js
        └── scss

நீங்கள் எங்கள் மூலக் கோப்புகளைப் பதிவிறக்கம் செய்து, தொகுப்பு மேலாளரைப் பயன்படுத்தவில்லை எனில், பூட்ஸ்டார்ப்பின் மூலக் கோப்புகளை உங்களின் சொந்தக் கோப்புகளிலிருந்து தனித்தனியாக வைத்து, அந்த அமைப்பைப் போன்ற ஒன்றை கைமுறையாக அமைக்க வேண்டும்.

your-project/
├── scss
│   └── custom.scss
└── bootstrap/
    ├── js
    └── scss

இறக்குமதி செய்கிறது

உங்கள் இல் custom.scss, நீங்கள் பூட்ஸ்டார்ப்பின் மூல சாஸ் கோப்புகளை இறக்குமதி செய்வீர்கள். உங்களுக்கு இரண்டு விருப்பங்கள் உள்ளன: பூட்ஸ்டார்ப் அனைத்தையும் சேர்க்கவும் அல்லது உங்களுக்குத் தேவையான பகுதிகளைத் தேர்ந்தெடுக்கவும். பிந்தையதை நாங்கள் ஊக்குவிக்கிறோம், இருப்பினும் எங்கள் கூறுகள் முழுவதும் சில தேவைகள் மற்றும் சார்புகள் உள்ளன. எங்கள் செருகுநிரல்களுக்கு நீங்கள் சில ஜாவாஸ்கிரிப்ட்களையும் சேர்க்க வேண்டும்.

// Custom.scss
// Option A: Include all of Bootstrap

@import "../node_modules/bootstrap/scss/bootstrap";
// Custom.scss
// Option B: Include parts of Bootstrap

// Required
@import "../node_modules/bootstrap/scss/functions";
@import "../node_modules/bootstrap/scss/variables";
@import "../node_modules/bootstrap/scss/mixins";

// Optional
@import "../node_modules/bootstrap/scss/reboot";
@import "../node_modules/bootstrap/scss/type";
@import "../node_modules/bootstrap/scss/images";
@import "../node_modules/bootstrap/scss/code";
@import "../node_modules/bootstrap/scss/grid";

அந்த அமைப்பில், உங்கள் சாஸ் மாறிகள் மற்றும் வரைபடங்களில் ஏதேனும் ஒன்றை நீங்கள் மாற்றத் தொடங்கலாம் custom.scss. // Optionalதேவைக்கேற்ப பிரிவின் கீழ் பூட்ஸ்டார்ப்பின் பகுதிகளைச் சேர்க்கத் தொடங்கலாம் . bootstrap.scssஉங்கள் தொடக்கப் புள்ளியாக எங்கள் கோப்பிலிருந்து முழு இறக்குமதி அடுக்கைப் பயன்படுத்த பரிந்துரைக்கிறோம் .

மாறி இயல்புநிலைகள்

பூட்ஸ்டார்ப் 4 இல் உள்ள ஒவ்வொரு Sass மாறியும், பூட்ஸ்டார்ப்பின் !defaultமூலக் குறியீட்டை மாற்றாமல் உங்கள் சொந்த Sass இல் மாறியின் இயல்புநிலை மதிப்பை மேலெழுத அனுமதிக்கும் கொடியை உள்ளடக்கியது. தேவைக்கேற்ப மாறிகளை நகலெடுத்து ஒட்டவும், அவற்றின் மதிப்புகளை மாற்றவும் மற்றும் !defaultகொடியை அகற்றவும். ஒரு மாறி ஏற்கனவே ஒதுக்கப்பட்டிருந்தால், பூட்ஸ்டார்ப்பில் உள்ள இயல்புநிலை மதிப்புகளால் அது மீண்டும் ஒதுக்கப்படாது.

பூட்ஸ்டார்ப்பின் மாறிகளின் முழுமையான பட்டியலை நீங்கள் இல் காணலாம் scss/_variables.scss. சில மாறிகள் க்கு அமைக்கப்பட்டுள்ளன null, இந்த மாறிகள் உங்கள் உள்ளமைவில் மேலெழுதப்படும் வரை சொத்தை வெளியிடாது.

அதே Sass கோப்பில் உள்ள மாறி மேலெழுதுதல் இயல்புநிலை மாறிகளுக்கு முன்னும் பின்னும் வரலாம். இருப்பினும், Sass கோப்புகள் முழுவதும் மேலெழுதும்போது, ​​பூட்ஸ்டார்ப்பின் Sass கோப்புகளை நீங்கள் இறக்குமதி செய்வதற்கு முன் உங்கள் மேலெழுதுதல்கள் வர வேண்டும்.

npm வழியாக பூட்ஸ்டார்ப்பை இறக்குமதி செய்து தொகுக்கும் போது background-colorமாற்றும் colorஒரு எடுத்துக்காட்டு இங்கே :<body>

// Your variable overrides
$body-bg: #000;
$body-color: #111;

// Bootstrap and its default variables
@import "../node_modules/bootstrap/scss/bootstrap";

கீழே உள்ள உலகளாவிய விருப்பங்கள் உட்பட, பூட்ஸ்டார்ப்பில் உள்ள எந்த மாறிக்கும் தேவையானதை மீண்டும் செய்யவும்.

வரைபடங்கள் மற்றும் சுழல்கள்

பூட்ஸ்டார்ப் 4 இல் ஒரு சில சாஸ் வரைபடங்கள் உள்ளன, முக்கிய மதிப்பு ஜோடிகள் தொடர்புடைய CSS குடும்பங்களை உருவாக்குவதை எளிதாக்குகிறது. எங்கள் வண்ணங்கள், கட்ட முறிவு புள்ளிகள் மற்றும் பலவற்றிற்கு சாஸ் வரைபடங்களைப் பயன்படுத்துகிறோம். Sass மாறிகளைப் போலவே, அனைத்து Sass வரைபடங்களும் !defaultகொடியை உள்ளடக்கியது மற்றும் மேலெழுதப்பட்டு நீட்டிக்கப்படலாம்.

எங்களின் சில Sass வரைபடங்கள் இயல்பாகவே காலியாக இணைக்கப்பட்டுள்ளன. கொடுக்கப்பட்ட சாஸ் வரைபடத்தை எளிதாக விரிவாக்க அனுமதிக்க இது செய்யப்படுகிறது, ஆனால் ஒரு வரைபடத்தில் இருந்து உருப்படிகளை அகற்றுவது சற்று கடினமாக இருக்கும்.

வரைபடத்தை மாற்றவும்

எங்கள் வரைபடத்தில் இருக்கும் நிறத்தை மாற்ற $theme-colors, பின்வருவனவற்றை உங்கள் தனிப்பயன் சாஸ் கோப்பில் சேர்க்கவும்:

$theme-colors: (
  "primary": #0074d9,
  "danger": #ff4136
);

வரைபடத்தில் சேர்க்கவும்

க்கு புதிய வண்ணத்தைச் $theme-colorsசேர்க்க, புதிய விசையையும் மதிப்பையும் சேர்க்கவும்:

$theme-colors: (
  "custom-color": #900
);

வரைபடத்திலிருந்து அகற்று

இலிருந்து வண்ணங்களை அகற்ற $theme-colors, அல்லது வேறு ஏதேனும் வரைபடத்தைப் பயன்படுத்தவும் map-remove. எங்கள் தேவைகள் மற்றும் விருப்பங்களுக்கு இடையில் நீங்கள் அதைச் செருக வேண்டும் என்பதை நினைவில் கொள்ளவும்:

// Required
@import "../node_modules/bootstrap/scss/functions";
@import "../node_modules/bootstrap/scss/variables";
@import "../node_modules/bootstrap/scss/mixins";

$theme-colors: map-remove($theme-colors, "info", "light", "dark");

// Optional
@import "../node_modules/bootstrap/scss/root";
@import "../node_modules/bootstrap/scss/reboot";
@import "../node_modules/bootstrap/scss/type";
...

தேவையான விசைகள்

சாஸ் வரைபடங்களில் சில குறிப்பிட்ட விசைகள் இருப்பதை பூட்ஸ்ட்ராப் கருதுகிறது. சேர்க்கப்பட்ட வரைபடங்களை நீங்கள் தனிப்பயனாக்கும்போது, ​​குறிப்பிட்ட Sass வரைபடத்தின் விசை பயன்படுத்தப்படும் இடத்தில் நீங்கள் பிழைகளை சந்திக்க நேரிடலாம்.

எடுத்துக்காட்டாக, இணைப்புகள், பொத்தான்கள் மற்றும் படிவ நிலைகளுக்கு primary, success, மற்றும் dangerவிசைகளைப் பயன்படுத்துகிறோம். $theme-colorsஇந்த விசைகளின் மதிப்புகளை மாற்றுவது எந்தச் சிக்கலையும் ஏற்படுத்தக்கூடாது, ஆனால் அவற்றை அகற்றுவது Sass தொகுப்பில் சிக்கல்களை ஏற்படுத்தலாம். இந்த நிகழ்வுகளில், அந்த மதிப்புகளைப் பயன்படுத்தும் சாஸ் குறியீட்டை நீங்கள் மாற்ற வேண்டும்.

செயல்பாடுகள்

பூட்ஸ்டார்ப் பல Sass செயல்பாடுகளைப் பயன்படுத்துகிறது, ஆனால் பொதுவான தீமிங்கிற்கு ஒரு துணைக்குழு மட்டுமே பொருந்தும். வண்ண வரைபடங்களிலிருந்து மதிப்புகளைப் பெறுவதற்கு மூன்று செயல்பாடுகளைச் சேர்த்துள்ளோம்:

@function color($key: "blue") {
  @return map-get($colors, $key);
}

@function theme-color($key: "primary") {
  @return map-get($theme-colors, $key);
}

@function gray($key: "100") {
  @return map-get($grays, $key);
}

V3 இலிருந்து ஒரு வண்ண மாறியைப் பயன்படுத்துவதைப் போலவே, சாஸ் வரைபடத்திலிருந்து ஒரு வண்ணத்தைத் தேர்ந்தெடுக்க இவை உங்களை அனுமதிக்கின்றன.

.custom-element {
  color: gray("100");
  background-color: theme-color("dark");
}

வரைபடத்திலிருந்து ஒரு குறிப்பிட்ட அளவிலான வண்ணத்தைப் பெறுவதற்கான மற்றொரு செயல்பாடும் எங்களிடம் உள்ளது. $theme-colorsஎதிர்மறை நிலை மதிப்புகள் நிறத்தை ஒளிரச் செய்யும், அதே நேரத்தில் அதிக அளவுகள் கருமையாக்கும்.

@function theme-color-level($color-name: "primary", $level: 0) {
  $color: theme-color($color-name);
  $color-base: if($level > 0, #000, #fff);
  $level: abs($level);

  @return mix($color-base, $color, $level * $theme-color-interval);
}

நடைமுறையில், நீங்கள் செயல்பாட்டை அழைத்து இரண்டு அளவுருக்களில் அனுப்புவீர்கள்: நிறத்தின் பெயர் $theme-colors(எ.கா. முதன்மை அல்லது ஆபத்து) மற்றும் எண் நிலை.

.custom-element {
  color: theme-color-level(primary, -10);
}

எதிர்காலத்தில் கூடுதல் செயல்பாடுகளைச் சேர்க்கலாம் அல்லது கூடுதல் சாஸ் வரைபடங்களுக்கான நிலை செயல்பாடுகளை உருவாக்க உங்கள் சொந்த தனிப்பயன் சாஸ் சேர்க்கப்படலாம், அல்லது நீங்கள் இன்னும் வாய்மொழியாக இருக்க விரும்பினால் பொதுவான ஒன்றைக் கூட செய்யலாம்.

வண்ண வேறுபாடு

பூட்ஸ்டார்ப்பில் நாம் சேர்க்கும் ஒரு கூடுதல் செயல்பாடு வண்ண மாறுபாடு செயல்பாடு ஆகும் color-yiq. குறிப்பிட்ட அடிப்படை நிறத்தின் அடிப்படையில் ஒரு ஒளி ( ) அல்லது இருண்ட ( ) மாறுபாடு வண்ணத்தை தானாகத் திரும்ப இது YIQ வண்ண இடத்தைப் பயன்படுத்துகிறது. நீங்கள் பல வகுப்புகளை உருவாக்கும் மிக்சின்கள் அல்லது லூப்களுக்கு இந்தச் செயல்பாடு மிகவும் பயனுள்ளதாக இருக்கும்.#fff#111

எடுத்துக்காட்டாக, எங்கள் $theme-colorsவரைபடத்திலிருந்து வண்ண ஸ்வாட்ச்களை உருவாக்க:

@each $color, $value in $theme-colors {
  .swatch-#{$color} {
    color: color-yiq($value);
  }
}

இது ஒரு-ஆஃப் கான்ட்ராஸ்ட் தேவைகளுக்கும் பயன்படுத்தப்படலாம்:

.custom-element {
  color: color-yiq(#000); // returns `color: #fff`
}

எங்கள் வண்ண வரைபட செயல்பாடுகளுடன் அடிப்படை நிறத்தையும் நீங்கள் குறிப்பிடலாம்:

.custom-element {
  color: color-yiq(theme-color("dark")); // returns `color: #fff`
}

சாஸ் விருப்பங்கள்

எங்கள் உள்ளமைக்கப்பட்ட தனிப்பயன் மாறிகள் கோப்புடன் பூட்ஸ்டார்ப் 4 ஐத் தனிப்பயனாக்குங்கள் மற்றும் புதிய $enable-*சாஸ் மாறிகள் மூலம் உலகளாவிய CSS விருப்பங்களை எளிதாக மாற்றலாம். ஒரு மாறியின் மதிப்பை மேலெழுதவும் மற்றும் 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 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-pointer-cursor-for-buttons true(இயல்புநிலை) அல்லதுfalse முடக்கப்படாத பொத்தான் கூறுகளுக்கு "கை" கர்சரைச் சேர்க்கவும்.
$enable-print-styles true(இயல்புநிலை) அல்லதுfalse அச்சிடுதலை மேம்படுத்துவதற்கான நடைகளை இயக்குகிறது.
$enable-responsive-font-sizes trueஅல்லது false(இயல்புநிலை) பதிலளிக்கக்கூடிய எழுத்துரு அளவுகளை இயக்குகிறது .
$enable-validation-icons true(இயல்புநிலை) அல்லதுfalse background-imageஉரை உள்ளீடுகளில் உள்ள ஐகான்கள் மற்றும் சரிபார்ப்பு நிலைகளுக்கான சில தனிப்பயன் படிவங்களை இயக்குகிறது .
$enable-deprecation-messages trueஅல்லது false(இயல்புநிலை) trueஇல் அகற்றப்படத் திட்டமிடப்பட்டுள்ள, நீக்கப்பட்ட மிக்சின்கள் மற்றும் செயல்பாடுகளில் ஏதேனும் ஒன்றைப் பயன்படுத்தும் போது எச்சரிக்கைகளைக் காட்ட அமைக்கவும் v5.

நிறம்

பல பூட்ஸ்டார்ப்பின் பல்வேறு கூறுகள் மற்றும் பயன்பாடுகள் சாஸ் வரைபடத்தில் வரையறுக்கப்பட்ட வண்ணங்களின் தொடர் மூலம் கட்டமைக்கப்படுகின்றன. இந்த வரைபடத்தை Sass இல் லூப் செய்து, தொடர்ச்சியான விதிகளை விரைவாக உருவாக்கலாம்.

அனைத்து வண்ணங்கள்

பூட்ஸ்டார்ப் 4 இல் கிடைக்கும் அனைத்து வண்ணங்களும் சாஸ் மாறிகள் மற்றும் சாஸ் வரைபடமாக scss/_variables.scssகோப்பில் கிடைக்கும். நாங்கள் ஏற்கனவே சேர்த்துள்ள கிரேஸ்கேல் தட்டு போன்ற கூடுதல் நிழல்களைச் சேர்க்க, அடுத்தடுத்த சிறு வெளியீடுகளில் இது விரிவாக்கப்படும் .

நீலம்
இண்டிகோ
ஊதா
இளஞ்சிவப்பு
சிவப்பு
ஆரஞ்சு
மஞ்சள்
பச்சை
டீல்
சியான்

உங்கள் சாஸில் இவற்றை எவ்வாறு பயன்படுத்தலாம் என்பது இங்கே:

// With variable
.alpha { color: $purple; }

// From the Sass map with our `color()` function
.beta { color: color("purple"); }

வண்ண பயன்பாட்டு வகுப்புகள் அமைப்பதற்கும் colorமற்றும் background-color.

எதிர்காலத்தில், கீழே உள்ள கிரேஸ்கேல் வண்ணங்களைப் பயன்படுத்தி ஒவ்வொரு வண்ணத்தின் நிழல்களுக்கும் சாஸ் வரைபடங்கள் மற்றும் மாறிகளை வழங்குவதை நோக்கமாகக் கொண்டுள்ளோம்.

தீம் வண்ணங்கள்

scss/_variables.scssபூட்ஸ்ட்ராப்ஸ் கோப்பில் சாஸ் மாறிகள் மற்றும் சாஸ் வரைபடமாக கிடைக்கும் வண்ணத் திட்டங்களை உருவாக்க சிறிய வண்ணத் தட்டுகளை உருவாக்க அனைத்து வண்ணங்களின் துணைக்குழுவைப் பயன்படுத்துகிறோம் .

முதன்மை
இரண்டாம் நிலை
வெற்றி
ஆபத்து
எச்சரிக்கை
தகவல்
ஒளி
இருள்

சாம்பல் நிறங்கள்

சாம்பல் நிற மாறிகளின் விரிவான தொகுப்பு மற்றும் scss/_variables.scssஉங்கள் திட்டம் முழுவதும் நிலையான சாம்பல் நிற நிழல்களுக்கான சாஸ் வரைபடம். இவை "கூல் கிரேஸ்" என்பதை நினைவில் கொள்ளவும், இவை நடுநிலை சாம்பல் நிறத்தை விட நுட்பமான நீல நிற தொனியை நோக்கி செல்கின்றன.

100
200
300
400
500
600
700
800
900

க்குள் scss/_variables.scss, பூட்ஸ்டார்ப்பின் வண்ண மாறிகள் மற்றும் சாஸ் வரைபடத்தைக் காணலாம். $colorsசாஸ் வரைபடத்தின் எடுத்துக்காட்டு இங்கே :

$colors: (
  "blue": $blue,
  "indigo": $indigo,
  "purple": $purple,
  "pink": $pink,
  "red": $red,
  "orange": $orange,
  "yellow": $yellow,
  "green": $green,
  "teal": $teal,
  "cyan": $cyan,
  "white": $white,
  "gray": $gray-600,
  "gray-dark": $gray-800
) !default;

பல கூறுகளில் அவை எவ்வாறு பயன்படுத்தப்படுகின்றன என்பதைப் புதுப்பிக்க வரைபடத்தில் மதிப்புகளைச் சேர்க்கவும், அகற்றவும் அல்லது மாற்றவும். துரதிருஷ்டவசமாக இந்த நேரத்தில், ஒவ்வொரு கூறுகளும் இந்த சாஸ் வரைபடத்தைப் பயன்படுத்துவதில்லை. எதிர்கால புதுப்பிப்புகள் இதை மேம்படுத்த முயற்சிக்கும். அதுவரை, ${color}மாறிகள் மற்றும் இந்த சாஸ் வரைபடத்தைப் பயன்படுத்த திட்டமிடுங்கள்.

கூறுகள்

பூட்ஸ்டார்ப்பின் பல கூறுகள் மற்றும் பயன்பாடுகள் @eachசாஸ் வரைபடத்தின் மீது மீண்டும் செயல்படும் சுழல்களால் கட்டமைக்கப்பட்டுள்ளன. எங்களால் ஒரு கூறுகளின் $theme-colorsமாறுபாடுகளை உருவாக்குவதற்கும், ஒவ்வொரு பிரேக் பாயிண்டிற்கும் பதிலளிக்கக்கூடிய மாறுபாடுகளை உருவாக்குவதற்கும் இது குறிப்பாக உதவியாக இருக்கும். நீங்கள் இந்த Sass வரைபடங்களைத் தனிப்பயனாக்கி, மீண்டும் தொகுக்கும்போது, ​​இந்த சுழல்களில் உங்கள் மாற்றங்கள் தானாகவே பிரதிபலிக்கும்.

மாற்றியமைப்பவர்கள்

பூட்ஸ்டார்ப்பின் பல கூறுகள் அடிப்படை-மாற்றி வகுப்பு அணுகுமுறையுடன் கட்டமைக்கப்பட்டுள்ளன. இதன் பொருள் ஸ்டைலிங்கின் பெரும்பகுதி அடிப்படை வகுப்பில் உள்ளது (எ.கா., .btn) அதே நேரத்தில் பாணி மாறுபாடுகள் மாற்றியமைக்கும் வகுப்புகளுக்கு மட்டுமே (எ.கா., .btn-danger). $theme-colorsஎங்கள் மாற்றி வகுப்புகளின் எண்ணிக்கை மற்றும் பெயரைத் தனிப்பயனாக்க வரைபடத்தில் இருந்து இந்த மாற்றி வகுப்புகள் உருவாக்கப்பட்டுள்ளன .

கூறு மற்றும் எங்களின் அனைத்து பின்னணிப் பயன்பாடுகளுக்கு $theme-colorsமாற்றியமைப்பதற்காக வரைபடத்தின் மீது நாம் எவ்வாறு லூப் செய்கிறோம் என்பதற்கான இரண்டு எடுத்துக்காட்டுகள் இங்கே உள்ளன ..alert.bg-*

// Generate alert modifier classes
@each $color, $value in $theme-colors {
  .alert-#{$color} {
    @include alert-variant(theme-color-level($color, -10), theme-color-level($color, -9), theme-color-level($color, 6));
  }
}

// Generate `.bg-*` color utilities
@each $color, $value in $theme-colors {
  @include bg-variant('.bg-#{$color}', $value);
}

பதிலளிக்கக்கூடியது

இந்த சாஸ் சுழல்கள் வண்ண வரைபடங்களுக்கு மட்டுப்படுத்தப்படவில்லை. உங்கள் கூறுகள் அல்லது பயன்பாடுகளின் பதிலளிக்கக்கூடிய மாறுபாடுகளையும் நீங்கள் உருவாக்கலாம். எடுத்துக்காட்டாக, எங்களின் பதிலளிக்கக்கூடிய உரை சீரமைப்புப் பயன்பாடுகளை எடுத்துக்கொள்வோம், அங்கு மீடியா வினவலுடன் சாஸ் வரைபடத்திற்கான @eachலூப்பைக் கலக்கிறோம்.$grid-breakpoints

@each $breakpoint in map-keys($grid-breakpoints) {
  @include media-breakpoint-up($breakpoint) {
    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);

    .text#{$infix}-left   { text-align: left !important; }
    .text#{$infix}-right  { text-align: right !important; }
    .text#{$infix}-center { text-align: center !important; }
  }
}

உங்கள் மாற்றங்களை நீங்கள் மாற்ற வேண்டும் என்றால் $grid-breakpoints, உங்கள் மாற்றங்கள் அந்த வரைபடத்தில் திரும்பும் அனைத்து சுழல்களுக்கும் பொருந்தும்.

CSS மாறிகள்

பூட்ஸ்டார்ப் 4 ஆனது அதன் தொகுக்கப்பட்ட CSS இல் சுமார் இரண்டு டஜன் CSS தனிப்பயன் பண்புகளை (மாறிகள்) உள்ளடக்கியது. உங்கள் உலாவியின் இன்ஸ்பெக்டர், குறியீடு சாண்ட்பாக்ஸ் அல்லது பொதுவான முன்மாதிரி ஆகியவற்றில் பணிபுரியும் போது, ​​எங்கள் தீம் வண்ணங்கள், பிரேக்பாயிண்ட்கள் மற்றும் முதன்மை எழுத்துரு அடுக்குகள் போன்ற பொதுவாகப் பயன்படுத்தப்படும் மதிப்புகளுக்கு இவை எளிதான அணுகலை வழங்குகின்றன.

கிடைக்கக்கூடிய மாறிகள்

இங்கே நாம் சேர்க்கும் மாறிகள் உள்ளன (அவை :rootதேவை என்பதை நினைவில் கொள்க). அவை எங்கள் _root.scssகோப்பில் உள்ளன.

:root {
  --blue: #007bff;
  --indigo: #6610f2;
  --purple: #6f42c1;
  --pink: #e83e8c;
  --red: #dc3545;
  --orange: #fd7e14;
  --yellow: #ffc107;
  --green: #28a745;
  --teal: #20c997;
  --cyan: #17a2b8;
  --white: #fff;
  --gray: #6c757d;
  --gray-dark: #343a40;
  --primary: #007bff;
  --secondary: #6c757d;
  --success: #28a745;
  --info: #17a2b8;
  --warning: #ffc107;
  --danger: #dc3545;
  --light: #f8f9fa;
  --dark: #343a40;
  --breakpoint-xs: 0;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --font-family-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  --font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

எடுத்துக்காட்டுகள்

CSS மாறிகள் Sass இன் மாறிகளுக்கு ஒத்த நெகிழ்வுத்தன்மையை வழங்குகின்றன, ஆனால் உலாவிக்கு வழங்குவதற்கு முன் தொகுக்க வேண்டிய அவசியமில்லை. எடுத்துக்காட்டாக, இங்கே நாங்கள் எங்கள் பக்கத்தின் எழுத்துரு மற்றும் இணைப்பு நடைகளை CSS மாறிகள் மூலம் மீட்டமைக்கிறோம்.

body {
  font: 1rem/1.5 var(--font-family-sans-serif);
}
a {
  color: var(--blue);
}

பிரேக் பாயிண்ட் மாறிகள்

நாங்கள் முதலில் எங்கள் CSS மாறிகளில் (எ.கா., --breakpoint-md) பிரேக் பாயிண்ட்டைச் சேர்த்திருந்தாலும், இவை மீடியா வினவல்களில் ஆதரிக்கப்படாது , ஆனால் அவை மீடியா வினவல்களில் விதிமுறைகளுக்குள் பயன்படுத்தப்படலாம் . இந்த பிரேக்பாயிண்ட் மாறிகள் பின்தங்கிய இணக்கத்தன்மைக்காக தொகுக்கப்பட்ட CSS இல் இருக்கும், அவை ஜாவாஸ்கிரிப்ட் மூலம் பயன்படுத்தப்படலாம். விவரக்குறிப்பில் மேலும் அறிக .

எது ஆதரிக்கப்படவில்லை என்பதற்கான எடுத்துக்காட்டு இங்கே :

@media (min-width: var(--breakpoint-sm)) {
  ...
}

ஆதரிக்கப்படுவதற்கு இங்கே ஒரு எடுத்துக்காட்டு :

@media (min-width: 768px) {
  .custom-element {
    color: var(--primary);
  }
}