Theming Bootstrap
Tilpas Bootstrap 4 med vores nye indbyggede Sass-variabler til globale stilpræferencer for nemme temaer og komponentændringer.
Introduktion
I Bootstrap 3 var tematikken stort set drevet af variable tilsidesættelser i LESS, tilpasset CSS og et separat temastilark, som vi inkluderede i vores dist
filer. Med en vis indsats kunne man fuldstændig redesigne udseendet af Bootstrap 3 uden at røre ved kernefilerne. Bootstrap 4 giver en velkendt, men lidt anderledes tilgang.
Nu udføres tematisering af Sass-variabler, Sass-kort og tilpasset CSS. Der er ikke mere dedikeret tema stylesheet; i stedet kan du aktivere det indbyggede tema for at tilføje gradienter, skygger og mere.
Sass
Brug vores Sass-kildefiler til at drage fordel af variabler, kort, mixins og mere. I vores build har vi øget Sass-afrundingspræcisionen til 6 (som standard er den 5) for at forhindre problemer med browserafrunding.
Filstruktur
Når det er muligt, undgå at ændre Bootstraps kernefiler. For Sass betyder det at oprette dit eget stylesheet, der importerer Bootstrap, så du kan ændre og udvide det. Hvis du antager, at du bruger en pakkehåndtering som npm, vil du have en filstruktur, der ser sådan ud:
Hvis du har downloadet vores kildefiler og ikke bruger en pakkehåndtering, vil du manuelt opsætte noget, der ligner den struktur, og holde Bootstraps kildefiler adskilt fra dine egne.
Importerer
I din custom.scss
vil du importere Bootstraps kilde Sass-filer. Du har to muligheder: medtag hele Bootstrap, eller vælg de dele, du har brug for. Vi opfordrer til sidstnævnte, men vær opmærksom på, at der er nogle krav og afhængigheder på tværs af vores komponenter. Du skal også inkludere noget JavaScript til vores plugins.
Med den opsætning på plads kan du begynde at ændre enhver af Sass-variablerne og -kortene i din custom.scss
. Du kan også begynde at tilføje dele af Bootstrap under // Optional
sektionen efter behov. Vi foreslår, at du bruger den fulde importstak fra vores bootstrap.scss
fil som dit udgangspunkt.
Variable standardindstillinger
Hver Sass-variabel i Bootstrap 4 inkluderer !default
flaget, der giver dig mulighed for at tilsidesætte variablens standardværdi i din egen Sass uden at ændre Bootstraps kildekode. Kopier og indsæt variabler efter behov, rediger deres værdier, og fjern !default
flaget. Hvis en variabel allerede er blevet tildelt, vil den ikke blive gentildelt af standardværdierne i Bootstrap.
Du finder den komplette liste over Bootstraps variabler i scss/_variables.scss
.
Variabeltilsidesættelser inden for den samme Sass-fil kan komme før eller efter standardvariablerne. Men når du tilsidesætter på tværs af Sass-filer, skal dine tilsidesættelser komme, før du importerer Bootstraps Sass-filer.
Her er et eksempel, der ændrer background-color
og color
for, <body>
når du importerer og kompilerer Bootstrap via npm:
Gentag efter behov for enhver variabel i Bootstrap, inklusive de globale muligheder nedenfor.
Kort og sløjfer
Bootstrap 4 inkluderer en håndfuld Sass-kort, nøgleværdipar, der gør det nemmere at generere familier af relateret CSS. Vi bruger Sass-kort til vores farver, gitterbrudpunkter og mere. Ligesom Sass-variabler inkluderer alle Sass-kort !default
flaget og kan tilsidesættes og udvides.
Nogle af vores Sass-kort er som standard flettet sammen til tomme kort. Dette gøres for at tillade let udvidelse af et givet Sass-kort, men det koster det at gøre det lidt vanskeligere at fjerne elementer fra et kort.
Rediger kort
For at ændre en eksisterende farve på vores $theme-colors
kort skal du tilføje følgende til din tilpassede Sass-fil:
Tilføj til kort
For at tilføje en ny farve til $theme-colors
skal du tilføje den nye nøgle og værdi:
Fjern fra kortet
For at fjerne farver fra $theme-colors
eller et hvilket som helst andet kort, brug map-remove
. Vær opmærksom på, at du skal indsætte det mellem vores krav og muligheder:
Nødvendige nøgler
Bootstrap antager tilstedeværelsen af nogle specifikke nøgler i Sass-kort, da vi brugte og udvider disse selv. Når du tilpasser de inkluderede kort, kan du støde på fejl, hvor en specifik Sass-kortnøgle bliver brugt.
For eksempel bruger vi tasterne primary
, success
, og danger
fra $theme-colors
til links, knapper og formulartilstande. Udskiftning af værdierne for disse nøgler skulle ikke give nogen problemer, men fjernelse af dem kan forårsage problemer med Sass-kompilering. I disse tilfælde skal du ændre den Sass-kode, der gør brug af disse værdier.
Funktioner
Bootstrap bruger adskillige Sass-funktioner, men kun en delmængde kan anvendes til generelle temaer. Vi har inkluderet tre funktioner til at hente værdier fra farvekortene:
Disse giver dig mulighed for at vælge én farve fra et Sass-kort, ligesom du ville bruge en farvevariabel fra v3.
Vi har også en anden funktion til at få et bestemt farveniveau fra $theme-colors
kortet. Negative niveauværdier vil gøre farven lysere, mens højere niveauer bliver mørkere.
I praksis ville du kalde funktionen og sende to parametre ind: navnet på farven fra $theme-colors
(f.eks. primær eller fare) og et numerisk niveau.
Yderligere funktioner kan tilføjes i fremtiden eller din egen tilpassede Sass for at skabe niveaufunktioner til yderligere Sass-kort, eller endda en generisk, hvis du ville være mere udførlig.
Farvekontrast
En ekstra funktion, vi inkluderer i Bootstrap, er farvekontrastfunktionen, color-yiq
. Den bruger YIQ-farverummet til automatisk at returnere en lys ( #fff
) eller mørk ( #111
) kontrastfarve baseret på den angivne grundfarve. Denne funktion er især nyttig til mixins eller loops, hvor du genererer flere klasser.
For eksempel, for at generere farveprøver fra vores $theme-colors
kort:
Den kan også bruges til engangskontrastbehov:
Du kan også angive en grundfarve med vores farvekortfunktioner:
Sass muligheder
Tilpas Bootstrap 4 med vores indbyggede tilpassede variabelfil, og skift nemt globale CSS-præferencer med nye $enable-*
Sass-variabler. Tilsidesæt en variabels værdi, og kompiler igen med npm run test
efter behov.
Du kan finde og tilpasse disse variabler til vigtige globale muligheder i Bootstraps scss/_variables.scss
fil.
Variabel | Værdier | Beskrivelse |
---|---|---|
$spacer |
1rem (standard) eller en hvilken som helst værdi > 0 |
Angiver standardafstandsværdien til programmæssig generering af vores spacerværktøjer . |
$enable-rounded |
true (standard) ellerfalse |
Aktiverer foruddefinerede border-radius stilarter på forskellige komponenter. |
$enable-shadows |
true eller false (standard) |
Aktiverer foruddefinerede box-shadow stilarter på forskellige komponenter. |
$enable-gradients |
true eller false (standard) |
Aktiverer foruddefinerede gradienter via background-image stilarter på forskellige komponenter. |
$enable-transitions |
true (standard) ellerfalse |
Aktiverer foruddefinerede transition s på forskellige komponenter. |
$enable-prefers-reduced-motion-media-query |
true (standard) ellerfalse |
Aktiverer prefers-reduced-motion medieforespørgslen , som undertrykker visse animationer/overgange baseret på brugernes browser-/operativsystempræferencer. |
$enable-hover-media-query |
true eller false (standard) |
Forældet |
$enable-grid-classes |
true (standard) ellerfalse |
Aktiverer generering af CSS-klasser til netsystemet (f.eks. .container , .row , .col-md-1 , osv.). |
$enable-caret |
true (standard) ellerfalse |
Aktiverer pseudo element caret på .dropdown-toggle . |
$enable-print-styles |
true (standard) ellerfalse |
Aktiverer stilarter til optimering af udskrivning. |
$enable-validation-icons |
true (standard) ellerfalse |
Aktiverer background-image ikoner i tekstinput og nogle brugerdefinerede formularer til valideringstilstande. |
Farve
Mange af Bootstraps forskellige komponenter og hjælpeprogrammer er bygget gennem en række farver defineret i et Sass-kort. Dette kort kan løkkes i Sass for hurtigt at generere en række regelsæt.
Alle farver
Alle farver, der er tilgængelige i Bootstrap 4, er tilgængelige som Sass-variabler og et Sass-kort i scss/_variables.scss
fil. Dette vil blive udvidet i efterfølgende mindre udgivelser for at tilføje yderligere nuancer, ligesom den gråtonepalet , vi allerede inkluderer.
Sådan kan du bruge disse i din Sass:
Farvefunktionsklasser er også tilgængelige for indstilling color
og background-color
.
I fremtiden vil vi tilstræbe at levere Sass-kort og variabler for nuancer af hver farve, som vi har gjort med gråtonefarverne nedenfor.
Tema farver
Vi bruger et undersæt af alle farver til at skabe en mindre farvepalet til generering af farveskemaer, også tilgængelig som Sass-variabler og et Sass-kort i Bootstraps's scss/_variables.scss
fil.
Grå
Et omfattende sæt af grå variabler og et Sass-kort scss/_variables.scss
til ensartede gråtoner på tværs af dit projekt. Bemærk, at disse er "seje grå", som har en tendens til en subtil blå tone, snarere end neutrale gråtoner.
Indenfor scss/_variables.scss
finder du Bootstraps farvevariabler og Sass-kort. Her er et eksempel på $colors
Sass-kortet:
Tilføj, fjern eller rediger værdier på kortet for at opdatere, hvordan de bruges i mange andre komponenter. Desværre på nuværende tidspunkt er det ikke alle komponenter, der bruger dette Sass-kort. Fremtidige opdateringer vil bestræbe sig på at forbedre dette. Indtil da, planlæg at gøre brug af ${color}
variablerne og dette Sass-kort.
Komponenter
Mange af Bootstraps komponenter og hjælpeprogrammer er bygget med @each
loops, der itererer over et Sass-kort. Dette er især nyttigt til at generere varianter af en komponent af vores $theme-colors
og skabe responsive varianter for hvert breakpoint. Når du tilpasser disse Sass-kort og kompilerer igen, vil du automatisk se dine ændringer afspejlet i disse loops.
Modifikatorer
Mange af Bootstraps komponenter er bygget med en base-modifier klasse tilgang. Dette betyder, at hovedparten af stylingen er indeholdt i en basisklasse (f.eks. .btn
), mens stilvariationer er begrænset til modifikatorklasser (f.eks. .btn-danger
). Disse modifikatorklasser er bygget ud fra $theme-colors
kortet for at tilpasse antallet og navnet på vores modifikatorklasser.
Her er to eksempler på, hvordan vi looper over $theme-colors
kortet for at generere modifikatorer til .alert
komponenten og alle vores .bg-*
baggrundsværktøjer.
Lydhør
Disse Sass-loops er heller ikke begrænset til farvekort. Du kan også generere responsive variationer af dine komponenter eller hjælpeprogrammer. Tag for eksempel vores responsive tekstjusteringsværktøjer, hvor vi blander en @each
loop til $grid-breakpoints
Sass-kortet med en medieforespørgsel.
Hvis du har brug for at ændre din $grid-breakpoints
, vil dine ændringer gælde for alle de loops, der itererer over det pågældende kort.
CSS variabler
Bootstrap 4 inkluderer omkring to dusin brugerdefinerede CSS-egenskaber (variabler) i dens kompilerede CSS. Disse giver nem adgang til almindeligt anvendte værdier som vores temafarver, brudpunkter og primære skrifttyper, når du arbejder i din browsers Inspector, en kodesandkasse eller generel prototyping.
Tilgængelige variabler
Her er de variabler, vi inkluderer (bemærk, at det :root
er påkrævet). De er placeret i vores _root.scss
fil.
Eksempler
CSS-variabler tilbyder samme fleksibilitet som Sass' variabler, men uden behov for kompilering, før de serveres til browseren. For eksempel nulstiller vi vores sides skrifttype og linkstile med CSS-variabler.
Breakpoint variabler
Selvom vi oprindeligt inkluderede brudpunkter i vores CSS-variabler (f.eks. --breakpoint-md
), understøttes disse ikke i medieforespørgsler , men de kan stadig bruges inden for regelsæt i medieforespørgsler. Disse brudpunktvariabler forbliver i den kompilerede CSS for bagudkompatibilitet, da de kan bruges af JavaScript. Lær mere i specifikationerne .
Her er et eksempel på, hvad der ikke understøttes:
Og her er et eksempel på, hvad der understøttes: