Bootstrap a tema
Personalizza Bootstrap 4 con le nostre nuove variabili Sass integrate per preferenze di stile globali per una facile modifica dei temi e dei componenti.
In Bootstrap 3, il tema è stato in gran parte guidato da sostituzioni di variabili in LESS, CSS personalizzato e un foglio di stile del tema separato che abbiamo incluso nei nostri dist
file. Con un certo sforzo, è possibile riprogettare completamente l'aspetto di Bootstrap 3 senza toccare i file principali. Bootstrap 4 fornisce un approccio familiare, ma leggermente diverso.
Ora, il tema è realizzato da variabili Sass, mappe Sass e CSS personalizzati. Non ci sono più fogli di stile tematici dedicati; invece, puoi abilitare il tema integrato per aggiungere sfumature, ombre e altro.
Utilizza i nostri file Sass di origine per sfruttare variabili, mappe, mixin e altro ancora.
Quando possibile, evita di modificare i file core di Bootstrap. Per Sass, ciò significa creare il tuo foglio di stile che importi Bootstrap in modo da poterlo modificare ed estendere. Supponendo che tu stia utilizzando un gestore di pacchetti come npm, avrai una struttura di file simile a questa:
Se hai scaricato i nostri file sorgente e non stai utilizzando un gestore di pacchetti, ti consigliamo di impostare manualmente qualcosa di simile a quella struttura, mantenendo i file sorgente di Bootstrap separati dai tuoi.
Nel tuo custom.scss
, importerai i file Sass di origine di Bootstrap. Hai due opzioni: includi tutto Bootstrap o scegli le parti di cui hai bisogno. Incoraggiamo quest'ultimo, anche se tieni presente che ci sono alcuni requisiti e dipendenze tra i nostri componenti. Dovrai anche includere alcuni JavaScript per i nostri plugin.
Con quella configurazione in atto, puoi iniziare a modificare qualsiasi variabile e mappa Sass nel tuo file custom.scss
. Puoi anche iniziare ad aggiungere parti di Bootstrap nella // Optional
sezione secondo necessità. Ti suggeriamo di utilizzare l'intero stack di importazione dal nostro bootstrap.scss
file come punto di partenza.
Ogni variabile Sass in Bootstrap 4 include il !default
flag che ti consente di sovrascrivere il valore predefinito della variabile nel tuo Sass senza modificare il codice sorgente di Bootstrap. Copia e incolla le variabili secondo necessità, modifica i loro valori e rimuovi il !default
flag. Se una variabile è già stata assegnata, non verrà riassegnata dai valori predefiniti in Bootstrap.
Le sostituzioni di variabili all'interno dello stesso file Sass possono venire prima o dopo le variabili predefinite. Tuttavia, quando si esegue l'override su file Sass, le sostituzioni devono avvenire prima dell'importazione dei file Sass di Bootstrap.
Ecco un esempio che cambia il background-color
e color
per <body>
durante l'importazione e la compilazione di Bootstrap tramite npm:
Ripetere se necessario per qualsiasi variabile in Bootstrap, comprese le opzioni globali di seguito.
Bootstrap 4 include una manciata di mappe Sass, coppie di valori chiave che semplificano la generazione di famiglie di CSS correlati. Usiamo le mappe Sass per i nostri colori, punti di interruzione della griglia e altro ancora. Proprio come le variabili Sass, tutte le mappe Sass includono il !default
flag e possono essere sovrascritte ed estese.
Alcune delle nostre mappe Sass sono unite in quelle vuote per impostazione predefinita. Questo viene fatto per consentire una facile espansione di una determinata mappa Sass, ma ha il costo di rendere leggermente più difficile la rimozione di oggetti da una mappa.
Per modificare un colore esistente nella nostra $theme-colors
mappa, aggiungi quanto segue al tuo file Sass personalizzato:
Per aggiungere un nuovo colore a $theme-colors
, aggiungi la nuova chiave e valore:
Per rimuovere i colori da $theme-colors
o da qualsiasi altra mappa, utilizzare map-remove
:
Bootstrap presuppone la presenza di alcune chiavi specifiche all'interno delle mappe Sass poiché le abbiamo utilizzate ed estese noi stessi. Mentre personalizzi le mappe incluse, potresti riscontrare errori in cui viene utilizzata la chiave di una specifica mappa Sass.
Ad esempio, utilizziamo i tasti primary
, success
, e di per collegamenti, pulsanti e stati dei moduli. La sostituzione dei valori di queste chiavi non dovrebbe presentare problemi, ma la loro rimozione potrebbe causare problemi di compilazione Sass. In questi casi, dovrai modificare il codice Sass che utilizza quei valori.danger
$theme-colors
Bootstrap utilizza diverse funzioni Sass, ma solo un sottoinsieme è applicabile ai temi generali. Abbiamo incluso tre funzioni per ottenere valori dalle mappe dei colori:
Questi ti consentono di scegliere un colore da una mappa Sass in modo molto simile a come useresti una variabile di colore dalla v3.
Abbiamo anche un'altra funzione per ottenere un particolare livello di colore dalla $theme-colors
mappa. I valori di livello negativi schiariranno il colore, mentre i livelli più alti lo scuriranno.
In pratica, chiamerai la funzione e passerai due parametri: il nome del colore da cui proviene $theme-colors
(es. primario o pericoloso) e un livello numerico.
Funzioni aggiuntive potrebbero essere aggiunte in futuro o il tuo Sass personalizzato per creare funzioni di livello per mappe Sass aggiuntive, o anche generico se vuoi essere più dettagliato.
Una funzione aggiuntiva che includiamo in Bootstrap è la funzione di contrasto del colore, color-yiq
. Utilizza lo spazio colore YIQ per restituire automaticamente un colore di contrasto chiaro ( #fff
) o scuro ( #111
) in base al colore di base specificato. Questa funzione è particolarmente utile per mixin o loop in cui stai generando più classi.
Ad esempio, per generare campioni di colore dalla nostra $theme-colors
mappa:
Può essere utilizzato anche per esigenze di contrasto una tantum:
Puoi anche specificare un colore di base con le nostre funzioni di mappatura dei colori:
Personalizza Bootstrap 4 con il nostro file di variabili personalizzate integrato e attiva facilmente le preferenze CSS globali con le nuove $enable-*
variabili Sass. Sostituisci il valore di una variabile e ricompila npm run test
secondo necessità.
Puoi trovare e personalizzare queste variabili per le opzioni globali chiave nel nostro _variables.scss
file.
Variabile | I valori | Descrizione |
---|---|---|
$spacer |
1rem (predefinito) o qualsiasi valore > 0 |
Specifica il valore di spaziatore predefinito per generare a livello di codice le nostre utilità spaziatore . |
$enable-rounded |
true (predefinito) ofalse |
border-radius Abilita stili predefiniti su vari componenti. |
$enable-shadows |
true o false (predefinito) |
box-shadow Abilita stili predefiniti su vari componenti. |
$enable-gradients |
true o false (predefinito) |
Abilita gradienti predefiniti tramite background-image stili su vari componenti. |
$enable-transitions |
true (predefinito) ofalse |
Abilita messaggi predefiniti transition su vari componenti. |
$enable-hover-media-query |
true o false (predefinito) |
Deprecato |
$enable-grid-classes |
true (predefinito) ofalse |
Abilita la generazione di classi CSS per il sistema a griglia (es. .container , .row , .col-md-1 , ecc.). |
$enable-caret |
true (predefinito) ofalse |
Abilita lo pseudo elemento accento circonflesso su .dropdown-toggle . |
$enable-print-styles |
true (predefinito) ofalse |
Abilita gli stili per ottimizzare la stampa. |
Molti dei vari componenti e utilità di Bootstrap sono costruiti attraverso una serie di colori definiti in una mappa Sass. Questa mappa può essere riprodotta in loop in Sass per generare rapidamente una serie di set di regole.
Tutti i colori disponibili in Bootstrap 4 sono disponibili come variabili Sass e mappa Sass nel nostro scss/_variables.scss
file. Questo verrà ampliato nelle successive versioni minori per aggiungere ulteriori sfumature, proprio come la tavolozza della scala di grigi che già includiamo.
Ecco come puoi usarli nel tuo Sass:
Le classi di utilità del colore sono disponibili anche per l'impostazione color
e background-color
.
In futuro, mireremo a fornire mappe e variabili Sass per le sfumature di ciascun colore, come abbiamo fatto con i colori in scala di grigi di seguito.
Usiamo un sottoinsieme di tutti i colori per creare una tavolozza di colori più piccola per la generazione di schemi di colori, disponibili anche come variabili Sass e una mappa Sass nel nostro scss/_variables.scss
file.
Un ampio set di variabili grigie e una mappa Sass scss/_variables.scss
per sfumature di grigio coerenti in tutto il tuo progetto.
All'interno _variables.scss
troverai le nostre variabili colore e la mappa Sass. Ecco un esempio della $colors
mappa del Sass:
Aggiungi, rimuovi o modifica i valori all'interno della mappa per aggiornare il modo in cui vengono utilizzati in molti altri componenti. Sfortunatamente in questo momento, non tutti i componenti utilizzano questa mappa Sass. Gli aggiornamenti futuri si sforzeranno di migliorare questo aspetto. Fino ad allora, pianifica di utilizzare le ${color}
variabili e questa mappa Sass.
Molti dei componenti e delle utilità di Bootstrap sono costruiti con @each
loop che ripetono su una mappa Sass. Ciò è particolarmente utile per generare varianti di un componente tramite il nostro $theme-colors
e creare varianti reattive per ogni punto di interruzione. Man mano che personalizzi queste mappe Sass e le ricompili, vedrai automaticamente le tue modifiche riflesse in questi loop.
Molti dei componenti di Bootstrap sono costruiti con un approccio di classe con modificatore di base. Ciò significa che la maggior parte dello stile è contenuta in una classe base (ad esempio, .btn
) mentre le variazioni di stile sono limitate alle classi modificatori (ad esempio, .btn-danger
). Queste classi di modificatori sono costruite dalla $theme-colors
mappa per personalizzare il numero e il nome delle nostre classi di modificatori.
Ecco due esempi di come eseguiamo il loop sulla $theme-colors
mappa per generare modificatori per il .alert
componente e tutte le nostre .bg-*
utilità in background.
Anche questi loop Sass non si limitano alle mappe dei colori. Puoi anche generare variazioni reattive dei tuoi componenti o utilità. Prendi ad esempio le nostre utilità di allineamento del testo reattivo in cui mescoliamo un @each
ciclo per la $grid-breakpoints
mappa Sass con una query multimediale inclusa.
Se hai bisogno di modificare il tuo $grid-breakpoints
, le tue modifiche si applicheranno a tutti i loop che ripetono su quella mappa.
Bootstrap 4 include circa due dozzine di proprietà personalizzate CSS (variabili) nel CSS compilato. Questi forniscono un facile accesso ai valori di uso comune come i colori del tema, i punti di interruzione e gli stack di caratteri primari quando si lavora nell'Inspector del browser, in una sandbox del codice o nella prototipazione generale.
Ecco le variabili che includiamo (notare che :root
è obbligatorio). Si trovano nel nostro _root.scss
file.
Le variabili CSS offrono una flessibilità simile alle variabili di Sass, ma senza la necessità di essere compilate prima di essere servite al browser. Ad esempio, qui stiamo reimpostando il carattere della nostra pagina e gli stili di collegamento con le variabili CSS.
Puoi anche utilizzare le nostre variabili breakpoint nelle tue media query: