Utility API
Uslužni API je alat baziran na Sass-u za generiranje uslužnih klasa.
Bootstrap uslužni programi se generiraju pomoću našeg uslužnog API-ja i mogu se koristiti za izmjenu ili proširenje našeg zadanog skupa uslužnih klasa putem Sass-a. Naš uslužni API je baziran na nizu Sass mapa i funkcija za generiranje porodica klasa sa različitim opcijama. Ako niste upoznati sa Sass mapama, pročitajte službene Sass dokumente da započnete.
Mapa sadrži sve naše uslužne programe i kasnije se $utilities
spaja s vašom prilagođenom $utilities
mapom, ako postoji. Mapa uslužnih programa sadrži ključnu listu grupa komunalnih usluga koje prihvataju sljedeće opcije:
Opcija | Tip | Zadana vrijednost | Opis |
---|---|---|---|
property |
Obavezno | – | Ime svojstva, ovo može biti string ili niz stringova (npr. horizontalni dopuni ili margine). |
values |
Obavezno | – | Lista vrijednosti ili mapa ako ne želite da ime klase bude isto kao vrijednost. Ako null se koristi kao ključ mape, ne kompajlira se. |
class |
Opciono | null | Ime generirane klase. Ako nije naveden i property predstavlja niz stringova, class podrazumevano će biti prvi element property niza. |
css-var |
Opciono | false |
Boolean za generiranje CSS varijabli umjesto CSS pravila. |
local-vars |
Opciono | null | Mapa lokalnih CSS varijabli za generiranje uz CSS pravila. |
state |
Opciono | null | Lista varijanti pseudoklasa (npr. :hover ili :focus ) za generiranje. |
responsive |
Opciono | false |
Boolean koji pokazuje da li treba generirati responzivne klase. |
rfs |
Opciono | false |
Boolean za omogućavanje tečnosti ponovnog skaliranja sa RFS . |
print |
Opciono | false |
Boolean označava da li je potrebno generirati klase ispisa. |
rtl |
Opciono | true |
Boolean koji pokazuje da li uslužni program treba zadržati u RTL-u. |
API objasnio
Sve uslužne varijable se dodaju $utilities
varijabli unutar našeg _utilities.scss
stila. Svaka grupa uslužnih programa izgleda otprilike ovako:
$utilities: (
"opacity": (
property: opacity,
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
)
);
Što daje sljedeće:
.opacity-0 { opacity: 0; }
.opacity-25 { opacity: .25; }
.opacity-50 { opacity: .5; }
.opacity-75 { opacity: .75; }
.opacity-100 { opacity: 1; }
Nekretnina
Potrebni property
ključ mora biti postavljen za bilo koji uslužni program i mora sadržavati važeće CSS svojstvo. Ovo svojstvo se koristi u skupu pravila generiranog uslužnog programa. Kada je class
ključ izostavljen, on takođe služi kao podrazumevano ime klase. Razmotrite text-decoration
uslužni program:
$utilities: (
"text-decoration": (
property: text-decoration,
values: none underline line-through
)
);
Izlaz:
.text-decoration-none { text-decoration: none !important; }
.text-decoration-underline { text-decoration: underline !important; }
.text-decoration-line-through { text-decoration: line-through !important; }
Vrijednosti
Koristite values
ključ da odredite koje vrijednosti za navedene property
treba koristiti u generiranim imenima klasa i pravilima. Može biti lista ili mapa (podešena u uslužnim programima ili u Sass varijabli).
Kao spisak, kao sa text-decoration
uslužnim programima :
values: none underline line-through
Kao mapa, kao sa opacity
uslužnim programima :
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
Kao Sass varijabla koja postavlja listu ili mapu, kao u našim position
uslužnim programima :
values: $position-values
Klasa
Koristite class
opciju da promijenite prefiks klase koji se koristi u prevedenom CSS-u. Na primjer, da promijenite iz .opacity-*
u .o-*
:
$utilities: (
"opacity": (
property: opacity,
class: o,
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
)
);
Izlaz:
.o-0 { opacity: 0 !important; }
.o-25 { opacity: .25 !important; }
.o-50 { opacity: .5 !important; }
.o-75 { opacity: .75 !important; }
.o-100 { opacity: 1 !important; }
CSS varijabilni uslužni programi
Postavite css-var
booleovu opciju na true
i API će generirati lokalne CSS varijable za dati selektor umjesto uobičajenih property: value
pravila. Razmotrite naše .text-opacity-*
komunalne usluge:
$utilities: (
"text-opacity": (
css-var: true,
class: text-opacity,
values: (
25: .25,
50: .5,
75: .75,
100: 1
)
),
);
Izlaz:
.text-opacity-25 { --bs-text-opacity: .25; }
.text-opacity-50 { --bs-text-opacity: .5; }
.text-opacity-75 { --bs-text-opacity: .75; }
.text-opacity-100 { --bs-text-opacity: 1; }
Lokalne CSS varijable
Koristite local-vars
opciju da navedete Sass mapu koja će generirati lokalne CSS varijable unutar skupa pravila uslužne klase. Imajte na umu da može biti potreban dodatni rad da se te lokalne CSS varijable koriste u generiranim CSS pravilima. Na primjer, razmotrite naše .bg-*
komunalne usluge:
$utilities: (
"background-color": (
property: background-color,
class: bg,
local-vars: (
"bg-opacity": 1
),
values: map-merge(
$utilities-bg-colors,
(
"transparent": transparent
)
)
)
);
Izlaz:
.bg-primary {
--bs-bg-opacity: 1;
background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;
}
države
Koristite state
opciju za generiranje varijacija pseudo-klase. Primjeri pseudoklasa su :hover
i :focus
. Kada se pruži lista stanja, kreiraju se imena klasa za tu pseudo-klasu. Na primjer, da promijenite neprozirnost pri lebdenju, dodajte state: hover
i ući ćete .opacity-hover:hover
u svoj prevedeni CSS.
Trebate više pseudo-klasa? Koristite listu stanja razdvojenu razmakom: state: hover focus
.
$utilities: (
"opacity": (
property: opacity,
class: opacity,
state: hover,
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
)
);
Izlaz:
.opacity-0-hover:hover { opacity: 0 !important; }
.opacity-25-hover:hover { opacity: .25 !important; }
.opacity-50-hover:hover { opacity: .5 !important; }
.opacity-75-hover:hover { opacity: .75 !important; }
.opacity-100-hover:hover { opacity: 1 !important; }
Responsive
Dodajte responsive
boolean za generiranje odgovarajućih uslužnih programa (npr. .opacity-md-25
) u svim tačkama prekida .
$utilities: (
"opacity": (
property: opacity,
responsive: true,
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
)
);
Izlaz:
.opacity-0 { opacity: 0 !important; }
.opacity-25 { opacity: .25 !important; }
.opacity-50 { opacity: .5 !important; }
.opacity-75 { opacity: .75 !important; }
.opacity-100 { opacity: 1 !important; }
@media (min-width: 576px) {
.opacity-sm-0 { opacity: 0 !important; }
.opacity-sm-25 { opacity: .25 !important; }
.opacity-sm-50 { opacity: .5 !important; }
.opacity-sm-75 { opacity: .75 !important; }
.opacity-sm-100 { opacity: 1 !important; }
}
@media (min-width: 768px) {
.opacity-md-0 { opacity: 0 !important; }
.opacity-md-25 { opacity: .25 !important; }
.opacity-md-50 { opacity: .5 !important; }
.opacity-md-75 { opacity: .75 !important; }
.opacity-md-100 { opacity: 1 !important; }
}
@media (min-width: 992px) {
.opacity-lg-0 { opacity: 0 !important; }
.opacity-lg-25 { opacity: .25 !important; }
.opacity-lg-50 { opacity: .5 !important; }
.opacity-lg-75 { opacity: .75 !important; }
.opacity-lg-100 { opacity: 1 !important; }
}
@media (min-width: 1200px) {
.opacity-xl-0 { opacity: 0 !important; }
.opacity-xl-25 { opacity: .25 !important; }
.opacity-xl-50 { opacity: .5 !important; }
.opacity-xl-75 { opacity: .75 !important; }
.opacity-xl-100 { opacity: 1 !important; }
}
@media (min-width: 1400px) {
.opacity-xxl-0 { opacity: 0 !important; }
.opacity-xxl-25 { opacity: .25 !important; }
.opacity-xxl-50 { opacity: .5 !important; }
.opacity-xxl-75 { opacity: .75 !important; }
.opacity-xxl-100 { opacity: 1 !important; }
}
Omogućavanje print
opcije će takođe generisati uslužne klase za štampanje, koje se primenjuju samo u okviru @media print { ... }
upita za medije.
$utilities: (
"opacity": (
property: opacity,
print: true,
values: (
0: 0,
25: .25,
50: .5,
75: .75,
100: 1,
)
)
);
Izlaz:
.opacity-0 { opacity: 0 !important; }
.opacity-25 { opacity: .25 !important; }
.opacity-50 { opacity: .5 !important; }
.opacity-75 { opacity: .75 !important; }
.opacity-100 { opacity: 1 !important; }
@media print {
.opacity-print-0 { opacity: 0 !important; }
.opacity-print-25 { opacity: .25 !important; }
.opacity-print-50 { opacity: .5 !important; }
.opacity-print-75 { opacity: .75 !important; }
.opacity-print-100 { opacity: 1 !important; }
}
Važnost
Svi uslužni programi koje generira API uključuju !important
kako bi se osiguralo da nadjačavaju komponente i klase modifikatora kako je predviđeno. Ovu postavku možete globalno promijeniti pomoću $enable-important-utilities
varijable (podrazumevano na true
).
Korištenje API-ja
Sada kada ste upoznati s načinom na koji API uslužnih programa radi, naučite kako dodati vlastite prilagođene klase i modificirati naše zadane uslužne programe.
Nadjačajte uslužne programe
Zaobiđite postojeće uslužne programe koristeći isti ključ. Na primjer, ako želite dodatne responzivne uslužne klase za prelijevanje, možete učiniti ovo:
$utilities: (
"overflow": (
responsive: true,
property: overflow,
values: visible hidden scroll auto,
),
);
Dodajte uslužne programe
Novi uslužni programi se mogu dodati na zadanu $utilities
kartu sa map-merge
. Provjerite _utilities.scss
jesu li naše potrebne Sass datoteke i prvo uvezene, a zatim koristite map-merge
za dodavanje dodatnih uslužnih programa. Na primjer, evo kako dodati odgovarajući cursor
uslužni program s tri vrijednosti.
@import "bootstrap/scss/functions";
@import "bootstrap/scss/variables";
@import "bootstrap/scss/utilities";
$utilities: map-merge(
$utilities,
(
"cursor": (
property: cursor,
class: cursor,
responsive: true,
values: auto pointer grab,
)
)
);
Modificirajte uslužne programe
Izmijenite postojeće uslužne programe u zadanoj $utilities
mapi sa map-get
i map-merge
funkcijama. U donjem primjeru dodajemo dodatnu vrijednost width
uslužnim programima. Počnite s inicijalom map-merge
, a zatim odredite koji uslužni program želite izmijeniti. Odatle dohvatite ugniježđenu "width"
kartu pomoću map-get
da biste pristupili i izmijenili opcije i vrijednosti uslužnog programa.
@import "bootstrap/scss/functions";
@import "bootstrap/scss/variables";
@import "bootstrap/scss/utilities";
$utilities: map-merge(
$utilities,
(
"width": map-merge(
map-get($utilities, "width"),
(
values: map-merge(
map-get(map-get($utilities, "width"), "values"),
(10: 10%),
),
),
),
)
);
Omogući odgovor
Možete omogućiti responzivne klase za postojeći skup uslužnih programa koji trenutno ne reagiraju prema zadanim postavkama. Na primjer, da bi border
klase bile prilagodljive:
@import "bootstrap/scss/functions";
@import "bootstrap/scss/variables";
@import "bootstrap/scss/utilities";
$utilities: map-merge(
$utilities, (
"border": map-merge(
map-get($utilities, "border"),
( responsive: true ),
),
)
);
Ovo će sada generirati prilagodljive varijacije .border
i .border-0
za svaku tačku prekida. Vaš generirani CSS će izgledati ovako:
.border { ... }
.border-0 { ... }
@media (min-width: 576px) {
.border-sm { ... }
.border-sm-0 { ... }
}
@media (min-width: 768px) {
.border-md { ... }
.border-md-0 { ... }
}
@media (min-width: 992px) {
.border-lg { ... }
.border-lg-0 { ... }
}
@media (min-width: 1200px) {
.border-xl { ... }
.border-xl-0 { ... }
}
@media (min-width: 1400px) {
.border-xxl { ... }
.border-xxl-0 { ... }
}
Preimenujte uslužne programe
Nedostaju v4 uslužni programi ili ste navikli na drugu konvenciju imenovanja? API uslužnih programa može se koristiti za nadjačavanje rezultata class
datog uslužnog programa—na primjer, za preimenovanje .ms-*
uslužnih programa u oldish .ml-*
:
@import "bootstrap/scss/functions";
@import "bootstrap/scss/variables";
@import "bootstrap/scss/utilities";
$utilities: map-merge(
$utilities, (
"margin-start": map-merge(
map-get($utilities, "margin-start"),
( class: ml ),
),
)
);
Uklonite uslužne programe
Uklonite bilo koji od zadanih uslužnih programa postavljanjem ključa grupe na null
. Na primjer, da biste uklonili sve naše width
uslužne programe, kreirajte $utilities
map-merge
i dodajte "width": null
unutar.
@import "bootstrap/scss/functions";
@import "bootstrap/scss/variables";
@import "bootstrap/scss/utilities";
$utilities: map-merge(
$utilities,
(
"width": null
)
);
Uklonite uslužni program u RTL-u
Neki rubni slučajevi otežavaju RTL stilizaciju , kao što su prijelomi linija na arapskom. Stoga se uslužni programi mogu izostaviti iz RTL izlaza postavljanjem rtl
opcije na false
:
$utilities: (
"word-wrap": (
property: word-wrap word-break,
class: text,
values: (break: break-word),
rtl: false
),
);
Izlaz:
/* rtl:begin:remove */
.text-break {
word-wrap: break-word !important;
word-break: break-word !important;
}
/* rtl:end:remove */
Ovo ne daje ništa u RTL-u, zahvaljujući RTLCSS remove
kontrolnoj direktivi .