Theming Bootstrap
Tilpass Bootstrap 4 med våre nye innebygde Sass-variabler for globale stilpreferanser for enkle tema- og komponentendringer.
I Bootstrap 3 ble tematikken i stor grad drevet av variable overstyringer i LESS, tilpasset CSS og et eget temastilark som vi inkluderte i dist
filene våre. Med litt innsats kunne man fullstendig redesigne utseendet til Bootstrap 3 uten å berøre kjernefilene. Bootstrap 4 gir en kjent, men litt annerledes tilnærming.
Nå er tematisering oppnådd av Sass-variabler, Sass-kart og tilpasset CSS. Det er ikke noe mer dedikert temastilark; i stedet kan du aktivere det innebygde temaet for å legge til gradienter, skygger og mer.
Bruk Sass-kildefilene våre for å dra nytte av variabler, kart, mixins og mer.
Når det er mulig, unngå å endre Bootstraps kjernefiler. For Sass betyr det å lage ditt eget stilark som importerer Bootstrap slik at du kan endre og utvide det. Forutsatt at du bruker en pakkebehandling som npm, vil du ha en filstruktur som ser slik ut:
Hvis du har lastet ned kildefilene våre og ikke bruker en pakkebehandling, vil du manuelt sette opp noe som ligner på den strukturen, og holde Bootstraps kildefiler atskilt fra dine egne.
I din custom.scss
vil du importere Bootstraps kilde Sass-filer. Du har to alternativer: ta med hele Bootstrap, eller velg delene du trenger. Vi oppfordrer sistnevnte, men vær oppmerksom på at det er noen krav og avhengigheter på tvers av komponentene våre. Du må også inkludere litt JavaScript for våre plugins.
Med det oppsettet på plass kan du begynne å endre alle Sass-variablene og kartene i custom.scss
. Du kan også begynne å legge til deler av Bootstrap under // Optional
seksjonen etter behov. Vi foreslår at du bruker hele importstabelen fra bootstrap.scss
filen vår som utgangspunkt.
Hver Sass-variabel i Bootstrap 4 inkluderer !default
flagget som lar deg overstyre variabelens standardverdi i din egen Sass uten å endre Bootstraps kildekode. Kopier og lim inn variabler etter behov, endre verdiene og fjern !default
flagget. Hvis en variabel allerede er tildelt, vil den ikke bli tildelt på nytt av standardverdiene i Bootstrap.
Du finner den komplette listen over Bootstraps variabler i scss/_variables.scss
.
Variabeloverstyringer i samme Sass-fil kan komme før eller etter standardvariablene. Men når du overstyrer på tvers av Sass-filer, må overstyringene dine komme før du importerer Bootstraps Sass-filer.
Her er et eksempel som endrer background-color
og color
for <body>
når du importerer og kompilerer Bootstrap via npm:
Gjenta etter behov for en hvilken som helst variabel i Bootstrap, inkludert de globale alternativene nedenfor.
Bootstrap 4 inkluderer en håndfull Sass-kart, nøkkelverdipar som gjør det enklere å generere familier med relatert CSS. Vi bruker Sass-kart for våre farger, rutenettbrytepunkter og mer. Akkurat som Sass-variabler, inkluderer alle Sass-kart !default
flagget og kan overstyres og utvides.
Noen av våre Sass-kart er slått sammen til tomme kart som standard. Dette gjøres for å tillate enkel utvidelse av et gitt Sass-kart, men kommer på bekostning av å gjøre det litt vanskeligere å fjerne elementer fra et kart.
For å endre en eksisterende farge i $theme-colors
kartet vårt, legg til følgende i din egendefinerte Sass-fil:
For å legge til en ny farge til $theme-colors
, legg til den nye nøkkelen og verdien:
For å fjerne farger fra $theme-colors
eller andre kart, bruk map-remove
. Vær oppmerksom på at du må sette den inn mellom våre krav og alternativer:
Bootstrap antar tilstedeværelsen av noen spesifikke nøkler i Sass-kart slik vi brukte og utvider disse selv. Når du tilpasser de inkluderte kartene, kan du støte på feil der nøkkelen til en bestemt Sass-kart brukes.
For eksempel bruker vi tastene primary
, success
, og danger
fra $theme-colors
for lenker, knapper og skjematilstander. Å erstatte verdiene til disse nøklene bør ikke by på problemer, men fjerning av dem kan føre til Sass-kompileringsproblemer. I disse tilfellene må du endre Sass-koden som bruker disse verdiene.
Bootstrap bruker flere Sass-funksjoner, men bare et delsett er aktuelt for generell tematikk. Vi har inkludert tre funksjoner for å hente verdier fra fargekartene:
Disse lar deg velge én farge fra et Sass-kart omtrent som hvordan du ville brukt en fargevariabel fra v3.
Vi har også en annen funksjon for å få et bestemt fargenivå fra $theme-colors
kartet. Negative nivåverdier vil gjøre fargen lysere, mens høyere nivåer blir mørkere.
I praksis vil du kalle funksjonen og sende inn to parametere: navnet på fargen fra $theme-colors
(f.eks. primær eller fare) og et numerisk nivå.
Ytterligere funksjoner kan legges til i fremtiden eller din egen tilpassede Sass for å lage nivåfunksjoner for flere Sass-kart, eller til og med en generisk en hvis du ønsker å være mer detaljert.
En tilleggsfunksjon vi inkluderer i Bootstrap er fargekontrastfunksjonen, color-yiq
. Den bruker YIQ-fargerommet til automatisk å returnere en lys ( #fff
) eller mørk ( #111
) kontrastfarge basert på den angitte grunnfargen. Denne funksjonen er spesielt nyttig for mixins eller looper der du genererer flere klasser.
For eksempel, for å generere fargeprøver fra $theme-colors
kartet vårt:
Den kan også brukes til engangskontrastbehov:
Du kan også spesifisere en grunnfarge med våre fargekartfunksjoner:
Tilpass Bootstrap 4 med vår innebygde egendefinerte variabelfil og bytt enkelt globale CSS-preferanser med nye $enable-*
Sass-variabler. Overstyr en variabels verdi og kompiler på nytt med npm run test
etter behov.
Du kan finne og tilpasse disse variablene for viktige globale alternativer i Bootstraps scss/_variables.scss
fil.
Variabel | Verdier | Beskrivelse |
---|---|---|
$spacer |
1rem (standard), eller en hvilken som helst verdi > 0 |
Spesifiserer standard avstandsverdi for å programmere generere avstandsverktøyene våre . |
$enable-rounded |
true (standard) ellerfalse |
Aktiverer forhåndsdefinerte border-radius stiler på ulike komponenter. |
$enable-shadows |
true eller false (standard) |
Aktiverer forhåndsdefinerte box-shadow stiler på ulike komponenter. |
$enable-gradients |
true eller false (standard) |
Aktiverer forhåndsdefinerte gradienter via background-image stiler på ulike komponenter. |
$enable-transitions |
true (standard) ellerfalse |
Aktiverer forhåndsdefinerte transition s på ulike komponenter. |
$enable-hover-media-query |
true eller false (standard) |
Avviklet |
$enable-grid-classes |
true (standard) ellerfalse |
Aktiverer generering av CSS-klasser for nettsystemet (f.eks. .container , .row , .col-md-1 , osv.). |
$enable-caret |
true (standard) ellerfalse |
Aktiverer pseudoelement-caret på .dropdown-toggle . |
$enable-print-styles |
true (standard) ellerfalse |
Aktiverer stiler for å optimalisere utskrift. |
Mange av Bootstraps ulike komponenter og verktøy er bygget gjennom en serie farger definert i et Sass-kart. Dette kartet kan sløyfes i Sass for raskt å generere en rekke regelsett.
Alle farger tilgjengelig i Bootstrap 4, er tilgjengelige som Sass-variabler og et Sass-kart i scss/_variables.scss
fil. Dette vil bli utvidet i påfølgende mindre utgivelser for å legge til flere nyanser, omtrent som gråtonepaletten vi allerede inkluderer.
Slik kan du bruke disse i Sass:
Fargeverktøyklasser er også tilgjengelige for innstilling color
og background-color
.
I fremtiden vil vi ta sikte på å tilby Sass-kart og variabler for nyanser av hver farge, slik vi har gjort med gråtonefargene nedenfor.
Vi bruker et undersett av alle farger for å lage en mindre fargepalett for å generere fargeskjemaer, også tilgjengelig som Sass-variabler og et Sass-kart i Bootstraps- scss/_variables.scss
filen.
Et omfattende sett med grå variabler og et Sass-kart scss/_variables.scss
for konsekvente gråtoner på tvers av prosjektet.
Innenfor scss/_variables.scss
finner du Bootstraps fargevariabler og Sass-kart. Her er et eksempel på $colors
Sass-kartet:
Legg til, fjern eller endre verdier i kartet for å oppdatere hvordan de brukes i mange andre komponenter. Dessverre på dette tidspunktet er det ikke alle komponenter som bruker dette Sass-kartet. Fremtidige oppdateringer vil forsøke å forbedre dette. Inntil da, planlegg å bruke ${color}
variablene og dette Sass-kartet.
Mange av Bootstraps komponenter og verktøy er bygget med @each
løkker som itererer over et Sass-kart. Dette er spesielt nyttig for å generere varianter av en komponent av vår $theme-colors
og lage responsive varianter for hvert bruddpunkt. Når du tilpasser disse Sass-kartene og kompilerer på nytt, vil du automatisk se endringene dine reflektert i disse loopene.
Mange av Bootstraps komponenter er bygget med en base-modifier klasse tilnærming. Dette betyr at hoveddelen av stilen er inneholdt i en basisklasse (f.eks. .btn
), mens stilvariasjoner er begrenset til modifikatorklasser (f.eks. .btn-danger
). Disse modifikatorklassene er bygget fra $theme-colors
kartet for å tilpasse antallet og navnet på modifikatorklassene våre.
Her er to eksempler på hvordan vi går over $theme-colors
kartet for å generere modifikatorer til .alert
komponenten og alle .bg-*
bakgrunnsverktøyene våre.
Disse Sass-løkkene er heller ikke begrenset til fargekart. Du kan også generere responsive varianter av komponentene eller verktøyene dine. Ta for eksempel våre responsive tekstjusteringsverktøy der vi blander en @each
løkke for $grid-breakpoints
Sass-kartet med en medieforespørsel.
Hvis du trenger å endre $grid-breakpoints
, vil endringene gjelde for alle løkkene som itererer over det kartet.
Bootstrap 4 inkluderer rundt to dusin egendefinerte CSS-egenskaper (variabler) i sin kompilerte CSS. Disse gir enkel tilgang til ofte brukte verdier som våre temafarger, bruddpunkter og primære skriftstabler når du arbeider i nettleserens Inspector, en kodesandkasse eller generell prototyping.
Her er variablene vi inkluderer (merk at det :root
er obligatorisk). De ligger i _root.scss
filen vår.
CSS-variabler tilbyr lignende fleksibilitet som Sass sine variabler, men uten behov for kompilering før de blir servert til nettleseren. For eksempel, her tilbakestiller vi sidens font- og lenkestiler med CSS-variabler.
Selv om vi opprinnelig inkluderte bruddpunkter i CSS-variablene våre (f.eks. --breakpoint-md
), støttes ikke disse i mediespørringer , men de kan fortsatt brukes innenfor regelsett i mediespørringer. Disse bruddpunktvariablene forblir i den kompilerte CSS-en for bakoverkompatibilitet gitt at de kan brukes av JavaScript. Lær mer i spesifikasjonen.
Her er et eksempel på hva som ikke støttes:
Og her er et eksempel på hva som støttes: