Bootstrap je postaven na responzivních 12sloupcových mřížkách, rozvrženích a komponentách.
Bootstrap využívá určité prvky HTML a vlastnosti CSS, které vyžadují použití doctype HTML5. Zařaďte jej na začátek všech svých projektů.
- <!DOCTYPE html>
- <html lang = "cs" >
- ...
- </html>
Bootstrap nastavuje základní globální styly zobrazení, typografie a odkazů. Konkrétně my:
margin
na tělebackground-color: white;
nabody
@baseFontFamily
, @baseFontSize
, a @baseLineHeight
jako náš typografický základ@linkColor
a aplikujte podtržení odkazu pouze na:hover
Tyto styly lze nalézt v rámci scaffolding.less .
S Bootstrap 2 byl starý resetovací blok vynechán ve prospěch Normalize.css , projektu Nicolase Gallaghera , který také pohání HTML5 Boilerplate . I když používáme velkou část Normalize v rámci našeho reset.less , odstranili jsme některé prvky speciálně pro Bootstrap.
Výchozí mřížkový systém Bootstrap využívá 12 sloupců , což vytváří kontejner o šířce 940 pixelů bez aktivovaných responzivních funkcí . S přidaným responzivním souborem CSS se mřížka přizpůsobí na šířku 724 pixelů a 1170 pixelů v závislosti na vaší výřezu. Pod výřezy o velikosti 767 pixelů se sloupce změní na plynulé a svisle se skládají.
Pro jednoduché dvousloupcové rozvržení vytvořte a .row
a přidejte příslušný počet .span*
sloupců. Protože se jedná o 12sloupcovou mřížku, každý .span*
pokrývá určitý počet těchto 12 sloupců a měl by vždy přidat až 12 pro každý řádek (nebo počet sloupců v nadřazeném).
- <div class = "row" >
- <div class = "span4" > ... </div>
- <div class = "span8" > ... </div>
- </div>
V tomto příkladu máme .span4
a .span8
, což znamená celkem 12 sloupců a celý řádek.
Přesunout sloupce doprava pomocí .offset*
tříd. Každá třída zvětší levý okraj sloupce o celý sloupec. Například .offset4
přesune .span4
přes čtyři sloupce.
- <div class = "row" >
- <div class = "span4" > ... </div>
- <div class = "span3 offset2" > ... </div>
- </div>
Chcete-li obsah vnořit do výchozí mřížky, přidejte do existujícího sloupce nový .row
a sadu sloupců . Vnořené řádky by měly obsahovat sadu sloupců, jejichž součet odpovídá počtu sloupců nadřazeného prvku..span*
.span*
- <div class = "row" >
- <div class = "span9" >
- Sloupec úrovně 1
- <div class = "row" >
- <div class = "span6" > Úroveň 2 </div>
- <div class = "span3" > Úroveň 2 </div>
- </div>
- </div>
- </div>
Systém tekuté mřížky používá pro šířky sloupců procenta místo pixelů. Má stejné schopnosti odezvy jako náš systém s pevnou mřížkou a zajišťuje správné proporce pro klíčová rozlišení obrazovky a zařízení.
Udělejte z libovolného řádku "tekutý" změnou .row
na .row-fluid
. Třídy sloupců zůstávají stejné, takže je snadné přepínat mezi pevnými a tekutými mřížkami.
- <div class = "row-fluid" >
- <div class = "span4" > ... </div>
- <div class = "span8" > ... </div>
- </div>
Funguje stejným způsobem jako odsazení systému pevné mřížky: přidáním .offset*
do libovolného sloupce se posune o tolik sloupců.
- <div class = "row-fluid" >
- <div class = "span4" > ... </div>
- <div class = "span4 offset2" > ... </div>
- </div>
Vnořování s proměnlivými mřížkami je trochu jiné: počet vnořených sloupců by se neměl shodovat s počtem sloupců rodiče. Místo toho se obnoví každá úroveň vnořených sloupců, protože každý řádek zabírá 100 % nadřazeného sloupce.
- <div class = "row-fluid" >
- <div class = "span12" >
- Kapalina 12
- <div class = "row-fluid" >
- <div class = "span6" > Fluid 6 </div>
- <div class = "span6" > Fluid 6 </div>
- </div>
- </div>
- </div>
Poskytuje společné rozvržení s pevnou šířkou (a volitelně reagující) pouze s <div class="container">
požadovaným.
- <body>
- <div class = "container" >
- ...
- </div>
- </body>
Vytvořte plynulou stránku se dvěma sloupci pomocí <div class="container-fluid">
— skvělé pro aplikace a dokumenty.
- <div class = "container-fluid" >
- <div class = "row-fluid" >
- <div class = "span2" >
- <!--Obsah postranního panelu-->
- </div>
- <div class = "span10" >
- <!--Obsah těla-->
- </div>
- </div>
- </div>
Zapněte responzivní CSS ve svém projektu tím, že do dokumentu zahrnete správnou metaznačku a další šablonu stylů <head>
. Pokud jste zkompilovali Bootstrap ze stránky Přizpůsobit, musíte zahrnout pouze značku metadat.
- <meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
- <link href = "assets/css/bootstrap-responsive.css" rel = "stylesheet" >
Hlavy vzhůru!Bootstrap v tuto chvíli ve výchozím nastavení nezahrnuje responzivní funkce, protože ne vše musí reagovat. Místo nabádání vývojářů, aby tuto funkci odstranili, považujeme za nejlepší ji podle potřeby povolit.
Dotazy na média umožňují vlastní CSS založené na řadě podmínek – poměry, šířky, typ zobrazení atd. – ale obvykle se zaměřují kolem min-width
a max-width
.
Používejte mediální dotazy zodpovědně a pouze jako začátek pro vaše mobilní publikum. U větších projektů zvažte vyhrazené báze kódu a ne vrstvy dotazů na média.
Bootstrap podporuje několik mediálních dotazů v jednom souboru, aby pomohly vytvořit vaše projekty vhodnější na různých zařízeních a rozlišeních obrazovky. Zde je zahrnuto:
Označení | Šířka rozložení | Šířka sloupce | Šířka okapu |
---|---|---|---|
Velký displej | 1200px a více | 70 pixelů | 30 pixelů |
Výchozí | 980px a více | 60 pixelů | 20 pixelů |
Portrétní tablety | 768px a více | 42 pixelů | 20 pixelů |
Telefony až tablety | 767px a méně | Fluidní sloupce, žádné pevné šířky | |
Telefony | 480px a méně | Fluidní sloupce, žádné pevné šířky |
- /* Velká plocha */
- @media ( min - width : 1200px ) { ... }
- /* Tablet na výšku na šířku a plochu */
- @media ( min - width : 768px ) and ( max - width : 979px ) { ... }
- /* Telefon na šířku až tablet na výšku */
- @media ( max - width : 767px ) { ... }
- /* Telefony na šířku a dolů */
- @media ( max - width : 480px ) { ... }
Pro rychlejší vývoj přizpůsobený pro mobilní zařízení použijte tyto třídy nástrojů pro zobrazení a skrytí obsahu podle zařízení. Níže je tabulka dostupných tříd a jejich vliv na dané rozložení dotazu na média (označené podle zařízení). Lze je nalézt v responsive.less
.
Třída | Telefony767px a méně | Tablety979 až 768 pixelů | Stolní počítačeVýchozí |
---|---|---|---|
.visible-phone |
Viditelné | Skrytý | Skrytý |
.visible-tablet |
Skrytý | Viditelné | Skrytý |
.visible-desktop |
Skrytý | Skrytý | Viditelné |
.hidden-phone |
Skrytý | Viditelné | Viditelné |
.hidden-tablet |
Viditelné | Skrytý | Viditelné |
.hidden-desktop |
Viditelné | Viditelné | Skrytý |
Používejte na omezeném základě a vyhněte se vytváření zcela odlišných verzí stejného webu. Místo toho je použijte k doplnění prezentace každého zařízení. Responzivní nástroje by se neměly používat s tabulkami a jako takové nejsou podporovány.
Změňte velikost prohlížeče nebo načtěte na různých zařízeních a otestujte výše uvedené třídy.
Zelená zaškrtnutí označují, že třída je viditelná ve vašem aktuálním výřezu.
Zde zelené zaškrtnutí označují, že třída je ve vašem aktuálním výřezu skryta.