1
0
Fork 0
mirror of https://github.com/twbs/bootstrap.git synced 2022-11-09 12:25:43 -05:00

flip things around again, no more base class, try out some new stuff to keep responsive flex grid working

This commit is contained in:
Mark Otto 2016-02-06 10:51:59 -08:00
parent 94999c98cf
commit 414997baa8
15 changed files with 216 additions and 187 deletions

View file

@ -21,10 +21,10 @@
<div class="container">
<div class="row">
<div class="col col-md-3 push-md-9 bd-sidebar">
<div class="col-md-3 push-md-9 bd-sidebar">
{% include nav-docs.html %}
</div>
<div class="col col-md-9 pull-md-3 bd-content">
<div class="col-md-9 pull-md-3 bd-content">
<h1 class="bd-title" id="content">{{ page.title }}</h1>
{{ content }}
</div>

View file

@ -3,9 +3,11 @@
//
.bd-example-row {
.row {
margin-bottom: 1rem;
.row + .row {
margin-top: 1rem;
}
.row {
> .col,
> [class^="col-"] {
padding-top: .75rem;

View file

@ -43,7 +43,7 @@
<div class="row">
<div class="col col-sm-8 blog-main">
<div class="col-sm-8 blog-main">
<div class="blog-post">
<h2 class="blog-post-title">Sample blog post</h2>
@ -111,7 +111,7 @@
</div><!-- /.blog-main -->
<div class="col col-sm-3 offset-sm-1 blog-sidebar">
<div class="col-sm-3 offset-sm-1 blog-sidebar">
<div class="sidebar-module sidebar-module-inset">
<h4>About</h4>
<p>Etiam porta <em>sem malesuada magna</em> mollis euismod. Cras mattis consectetur purus sit amet fermentum. Aenean lacinia bibendum nulla sed consectetur.</p>

View file

@ -98,19 +98,19 @@
<!-- Three columns of text below the carousel -->
<div class="row">
<div class="col col-lg-4">
<div class="col-lg-4">
<img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
<h2>Heading</h2>
<p>Donec sed odio dui. Etiam porta sem malesuada magna mollis euismod. Nullam id dolor id nibh ultricies vehicula ut id elit. Morbi leo risus, porta ac consectetur ac, vestibulum at eros. Praesent commodo cursus magna.</p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!-- /.col-lg-4 -->
<div class="col col-lg-4">
<div class="col-lg-4">
<img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
<h2>Heading</h2>
<p>Duis mollis, est non commodo luctus, nisi erat porttitor ligula, eget lacinia odio sem nec elit. Cras mattis consectetur purus sit amet fermentum. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh.</p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!-- /.col-lg-4 -->
<div class="col col-lg-4">
<div class="col-lg-4">
<img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
<h2>Heading</h2>
<p>Donec sed odio dui. Cras justo odio, dapibus ac facilisis in, egestas eget quam. Vestibulum id ligula porta felis euismod semper. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus.</p>
@ -124,11 +124,11 @@
<hr class="featurette-divider">
<div class="row featurette">
<div class="col col-md-7">
<div class="col-md-7">
<h2 class="featurette-heading">First featurette heading. <span class="text-muted">It'll blow your mind.</span></h2>
<p class="lead">Donec ullamcorper nulla non metus auctor fringilla. Vestibulum id ligula porta felis euismod semper. Praesent commodo cursus magna, vel scelerisque nisl consectetur. Fusce dapibus, tellus ac cursus commodo.</p>
</div>
<div class="col col-md-5">
<div class="col-md-5">
<img class="featurette-image img-fluid center-block" data-src="holder.js/500x500/auto" alt="Generic placeholder image">
</div>
</div>
@ -136,11 +136,11 @@
<hr class="featurette-divider">
<div class="row featurette">
<div class="col col-md-7 push-md-5">
<div class="col-md-7 push-md-5">
<h2 class="featurette-heading">Oh yeah, it's that good. <span class="text-muted">See for yourself.</span></h2>
<p class="lead">Donec ullamcorper nulla non metus auctor fringilla. Vestibulum id ligula porta felis euismod semper. Praesent commodo cursus magna, vel scelerisque nisl consectetur. Fusce dapibus, tellus ac cursus commodo.</p>
</div>
<div class="col col-md-5 pull-md-7">
<div class="col-md-5 pull-md-7">
<img class="featurette-image img-fluid center-block" data-src="holder.js/500x500/auto" alt="Generic placeholder image">
</div>
</div>
@ -148,11 +148,11 @@
<hr class="featurette-divider">
<div class="row featurette">
<div class="col col-md-7">
<div class="col-md-7">
<h2 class="featurette-heading">And lastly, this one. <span class="text-muted">Checkmate.</span></h2>
<p class="lead">Donec ullamcorper nulla non metus auctor fringilla. Vestibulum id ligula porta felis euismod semper. Praesent commodo cursus magna, vel scelerisque nisl consectetur. Fusce dapibus, tellus ac cursus commodo.</p>
</div>
<div class="col col-md-5">
<div class="col-md-5">
<img class="featurette-image img-fluid center-block" data-src="holder.js/500x500/auto" alt="Generic placeholder image">
</div>
</div>

View file

@ -43,7 +43,7 @@
<div class="container-fluid">
<div class="row">
<div class="col col-sm-3 col-md-2 sidebar">
<div class="col-sm-3 col-md-2 sidebar">
<ul class="nav nav-sidebar">
<li class="active"><a href="#">Overview <span class="sr-only">(current)</span></a></li>
<li><a href="#">Reports</a></li>
@ -63,26 +63,26 @@
<li><a href="">Another nav item</a></li>
</ul>
</div>
<div class="col col-sm-9 offset-sm-3 col-md-10 offset-md-2 main">
<div class="col-sm-9 offset-sm-3 col-md-10 offset-md-2 main">
<h1 class="page-header">Dashboard</h1>
<div class="row placeholders">
<div class="col col-xs-6 col-sm-3 placeholder">
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="200" height="200" class="img-fluid" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col col-xs-6 col-sm-3 placeholder">
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="200" height="200" class="img-fluid" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col col-xs-6 col-sm-3 placeholder">
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="200" height="200" class="img-fluid" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>
</div>
<div class="col col-xs-6 col-sm-3 placeholder">
<div class="col-xs-6 col-sm-3 placeholder">
<img src="" width="200" height="200" class="img-fluid" alt="Generic placeholder thumbnail">
<h4>Label</h4>
<span class="text-muted">Something else</span>

View file

@ -30,56 +30,56 @@
<p>There are five tiers to the Bootstrap grid system, one for each range of devices we support. Each tier starts at a minimum viewport size and automatically applies to the larger devices unless overridden.</p>
<div class="row">
<div class="col col-xs-4">.col .col-xs-4</div>
<div class="col col-xs-4">.col .col-xs-4</div>
<div class="col col-xs-4">.col .col-xs-4</div>
<div class="col-xs-4">.col-xs-4</div>
<div class="col-xs-4">.col-xs-4</div>
<div class="col-xs-4">.col-xs-4</div>
</div>
<div class="row">
<div class="col col-sm-4">.col .col-sm-4</div>
<div class="col col-sm-4">.col .col-sm-4</div>
<div class="col col-sm-4">.col .col-sm-4</div>
<div class="col-sm-4">.col-sm-4</div>
<div class="col-sm-4">.col-sm-4</div>
<div class="col-sm-4">.col-sm-4</div>
</div>
<div class="row">
<div class="col col-md-4">.col .col-md-4</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
</div>
<div class="row">
<div class="col col-lg-4">.col .col-lg-4</div>
<div class="col col-lg-4">.col .col-lg-4</div>
<div class="col col-lg-4">.col .col-lg-4</div>
<div class="col-lg-4">.col-lg-4</div>
<div class="col-lg-4">.col-lg-4</div>
<div class="col-lg-4">.col-lg-4</div>
</div>
<div class="row">
<div class="col col-xl-4">.col .col-xl-4</div>
<div class="col col-xl-4">.col .col-xl-4</div>
<div class="col col-xl-4">.col .col-xl-4</div>
<div class="col-xl-4">.col-xl-4</div>
<div class="col-xl-4">.col-xl-4</div>
<div class="col-xl-4">.col-xl-4</div>
</div>
<h3>Three equal columns</h3>
<p>Get three equal-width columns <strong>starting at desktops and scaling to large desktops</strong>. On mobile devices, tablets and below, the columns will automatically stack.</p>
<div class="row">
<div class="col col-md-4">.col .col-md-4</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4">.col-md-4</div>
</div>
<h3>Three unequal columns</h3>
<p>Get three columns <strong>starting at desktops and scaling to large desktops</strong> of various widths. Remember, grid columns should add up to twelve for a single horizontal block. More than that, and columns start stacking no matter the viewport.</p>
<div class="row">
<div class="col col-md-3">.col .col-md-3</div>
<div class="col col-md-6">.col .col-md-6</div>
<div class="col col-md-3">.col .col-md-3</div>
<div class="col-md-3">.col-md-3</div>
<div class="col-md-6">.col-md-6</div>
<div class="col-md-3">.col-md-3</div>
</div>
<h3>Two columns</h3>
<p>Get two columns <strong>starting at desktops and scaling to large desktops</strong>.</p>
<div class="row">
<div class="col col-md-8">.col .col-md-8</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col-md-8">.col-md-8</div>
<div class="col-md-4">.col-md-4</div>
</div>
<h3>Full width, single column</h3>
@ -91,14 +91,14 @@
<p>Per the documentation, nesting is easy—just put a row of columns within an existing column. This gives you two columns <strong>starting at desktops and scaling to large desktops</strong>, with another two (equal widths) within the larger column.</p>
<p>At mobile device sizes, tablets and down, these columns and their nested columns will stack.</p>
<div class="row">
<div class="col col-md-8">
<div class="col-md-8">
.col-md-8
<div class="row">
<div class="col col-md-6">.col .col-md-6</div>
<div class="col col-md-6">.col .col-md-6</div>
<div class="col-md-6">.col-md-6</div>
<div class="col-md-6">.col-md-6</div>
</div>
</div>
<div class="col col-md-4">.col .col-md-4</div>
<div class="col-md-4">.col-md-4</div>
</div>
<hr>
@ -107,17 +107,17 @@
<p>The Bootstrap v4 grid system has five tiers of classes: xs (extra small), sm (small), md (medium), lg (large), and xl (extra large). You can use nearly any combination of these classes to create more dynamic and flexible layouts.</p>
<p>Each tier of classes scales up, meaning if you plan on setting the same widths for xs and sm, you only need to specify xs.</p>
<div class="row">
<div class="col col-xs-12 col-md-8">.col .col-xs-12 .col-md-8</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col-xs-12 col-md-8">.col-xs-12 .col-md-8</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<div class="row">
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<div class="row">
<div class="col col-xs-6">.col .col-xs-6</div>
<div class="col col-xs-6">.col .col-xs-6</div>
<div class="col-xs-6">.col-xs-6</div>
<div class="col-xs-6">.col-xs-6</div>
</div>
<hr>
@ -125,13 +125,13 @@
<h3>Mixed: mobile, tablet, and desktop</h3>
<p></p>
<div class="row">
<div class="col col-xs-12 col-sm-6 col-lg-8">.col .col-xs-12 .col-sm-6 .col-lg-8</div>
<div class="col col-xs-6 col-lg-4">.col .col-xs-6 .col-lg-4</div>
<div class="col-xs-12 col-sm-6 col-lg-8">.col-xs-12 .col-sm-6 .col-lg-8</div>
<div class="col-xs-6 col-lg-4">.col-xs-6 .col-lg-4</div>
</div>
<div class="row">
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
</div>
<hr>
@ -139,18 +139,18 @@
<h3>Column clearing</h3>
<p><a href="http://getbootstrap.com/css/#grid-responsive-resets">Clear floats</a> at specific breakpoints to prevent awkward wrapping with uneven content.</p>
<div class="row">
<div class="col col-xs-6 col-sm-3">
<div class="col-xs-6 col-sm-3">
.col-xs-6 .col-sm-3
<br>
Resize your viewport or check it out on your phone for an example.
</div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
<!-- Add the extra clearfix for only the required viewport -->
<div class="clearfix hidden-sm-up"></div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
</div>
<hr>
@ -158,12 +158,12 @@
<h3>Offset, push, and pull resets</h3>
<p>Reset offsets, pushes, and pulls at specific breakpoints.</p>
<div class="row">
<div class="col col-sm-5 col-md-6">.col .col-sm-5 .col-md-6</div>
<div class="col col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col .col-sm-5 .col-sm-offset-2 .col-md-6 .col-md-offset-0</div>
<div class="col-sm-5 col-md-6">.col-sm-5 .col-md-6</div>
<div class="col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col-sm-5 .col-sm-offset-2 .col-md-6 .col-md-offset-0</div>
</div>
<div class="row">
<div class="col col-sm-6 col-md-5 col-lg-6">.col .col-sm-6 .col-md-5 .col-lg-6</div>
<div class="col col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col .col-sm-6 .col-md-5 .col-md-offset-2 .col-lg-6 .col-lg-offset-0</div>
<div class="col-sm-6 col-md-5 col-lg-6">.col-sm-6 .col-md-5 .col-lg-6</div>
<div class="col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col-sm-6 .col-md-5 .col-md-offset-2 .col-lg-6 .col-lg-offset-0</div>
</div>

View file

@ -47,17 +47,17 @@
<div class="container">
<!-- Example row of columns -->
<div class="row">
<div class="col col-md-4">
<div class="col-md-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div>
<div class="col col-md-4">
<div class="col-md-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div>
<div class="col col-md-4">
<div class="col-md-4">
<h2>Heading</h2>
<p>Donec sed odio dui. Cras justo odio, dapibus ac facilisis in, egestas eget quam. Vestibulum id ligula porta felis euismod semper. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus.</p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>

View file

@ -47,18 +47,18 @@
<!-- Example row of columns -->
<div class="row">
<div class="col col-lg-4">
<div class="col-lg-4">
<h2>Safari bug warning!</h2>
<p class="text-danger">As of v9.0, Safari exhibits a bug in which resizing your browser horizontally causes rendering errors in the justified nav that are cleared upon refreshing.</p>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-primary" href="#" role="button">View details &raquo;</a></p>
</div>
<div class="col col-lg-4">
<div class="col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-primary" href="#" role="button">View details &raquo;</a></p>
</div>
<div class="col col-lg-4">
<div class="col-lg-4">
<h2>Heading</h2>
<p>Donec sed odio dui. Cras justo odio, dapibus ac facilisis in, egestas eget quam. Vestibulum id ligula porta felis euismod semper. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa.</p>
<p><a class="btn btn-primary" href="#" role="button">View details &raquo;</a></p>

View file

@ -45,7 +45,7 @@
</div>
<div class="row marketing">
<div class="col col-lg-6">
<div class="col-lg-6">
<h4>Subheading</h4>
<p>Donec id elit non mi porta gravida at eget metus. Maecenas faucibus mollis interdum.</p>
@ -56,7 +56,7 @@
<p>Maecenas sed diam eget risus varius blandit sit amet non magna.</p>
</div>
<div class="col col-lg-6">
<div class="col-lg-6">
<h4>Subheading</h4>
<p>Donec id elit non mi porta gravida at eget metus. Maecenas faucibus mollis interdum.</p>

View file

@ -34,7 +34,7 @@
<div class="row row-offcanvas row-offcanvas-right">
<div class="col col-xs-12 col-sm-9">
<div class="col-xs-12 col-sm-9">
<p class="pull-xs-right hidden-sm-up">
<button type="button" class="btn btn-primary btn-sm" data-toggle="offcanvas">Toggle nav</button>
</p>
@ -43,32 +43,32 @@
<p>This is an example to show the potential of an offcanvas layout pattern in Bootstrap. Try some responsive-range viewport sizes to see it in action.</p>
</div>
<div class="row">
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!--/span-->
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!--/span-->
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!--/span-->
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!--/span-->
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
</div><!--/span-->
<div class="col col-xs-6 col-lg-4">
<div class="col-xs-6 col-lg-4">
<h2>Heading</h2>
<p>Donec id elit non mi porta gravida at eget metus. Fusce dapibus, tellus ac cursus commodo, tortor mauris condimentum nibh, ut fermentum massa justo sit amet risus. Etiam porta sem malesuada magna mollis euismod. Donec sed odio dui. </p>
<p><a class="btn btn-secondary" href="#" role="button">View details &raquo;</a></p>
@ -76,7 +76,7 @@
</div><!--/row-->
</div><!--/span-->
<div class="col col-xs-6 col-sm-3 sidebar-offcanvas" id="sidebar">
<div class="col-xs-6 col-sm-3 sidebar-offcanvas" id="sidebar">
<div class="list-group">
<a href="#" class="list-group-item active">Link</a>
<a href="#" class="list-group-item">Link</a>

View file

@ -30,19 +30,29 @@ Chill? Awesome—keep reading for more information and some code snippets.
## Auto-layout columns
As mentioned above, flexbox grid columns will automatically layout with even widths. Add any number of `.col`s and you're good to go.
As mentioned above, flexbox grid columns will automatically layout with even widths. Add any number of `.col-*`s for each breakpoint you need and you're good to go.
<div class="bd-example-row">
{% example html %}
<div class="container">
<div class="row">
<div class="col">
<div class="col-xs">
One of two columns
</div>
<div class="col-xs">
One of two columns
</div>
</div>
</div>
<div class="container">
<div class="row">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
</div>
@ -56,13 +66,13 @@ Auto-layout for flexbox grid columns also means you can set the width of one col
{% example html %}
<div class="container">
<div class="row">
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col col-md-6">
<div class="col-xs-6">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
</div>
@ -78,35 +88,35 @@ Use the flexbox alignment utilities to vertically align columns.
{% example html %}
<div class="container">
<div class="row flex-items-xs-top">
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
</div>
<div class="row flex-items-xs-middle">
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
</div>
<div class="row flex-items-xs-bottom">
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
<div class="col">
<div class="col-xs">
One of three columns
</div>
</div>
@ -118,13 +128,13 @@ Use the flexbox alignment utilities to vertically align columns.
{% example html %}
<div class="container">
<div class="row">
<div class="col flex-xs-top">
<div class="col-xs flex-xs-top">
One of three columns
</div>
<div class="col flex-xs-middle">
<div class="col-xs flex-xs-middle">
One of three columns
</div>
<div class="col flex-xs-bottom">
<div class="col-xs flex-xs-bottom">
One of three columns
</div>
</div>
@ -140,42 +150,42 @@ Flexbox utilities for horizontal alignment also exist for a number of layout opt
{% example html %}
<div class="container">
<div class="row flex-items-xs-left">
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
</div>
<div class="row flex-items-xs-center">
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
</div>
<div class="row flex-items-xs-right">
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
</div>
<div class="row flex-items-xs-around">
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
</div>
<div class="row flex-items-xs-between">
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
<div class="col col-xs-4">
<div class="col-xs-4">
One of two columns
</div>
</div>

View file

@ -35,13 +35,13 @@ If you're using Bootstrap's compiled CSS, this the example you'll want to start
{% example html %}
<div class="container">
<div class="row">
<div class="col col-sm-4">
<div class="col-sm-4">
One of three columns
</div>
<div class="col col-sm-4">
<div class="col-sm-4">
One of three columns
</div>
<div class="col col-sm-4">
<div class="col-sm-4">
One of three columns
</div>
</div>
@ -268,31 +268,31 @@ Using a single set of `.col-md-*` grid classes, you can create a basic grid syst
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
<div class="col-md-1">md-1</div>
</div>
<div class="row">
<div class="col col-md-8">md-8</div>
<div class="col col-md-4">md-4</div>
<div class="col-md-8">md-8</div>
<div class="col-md-4">md-4</div>
</div>
<div class="row">
<div class="col col-md-4">md-4</div>
<div class="col col-md-4">md-4</div>
<div class="col col-md-4">md-4</div>
<div class="col-md-4">md-4</div>
<div class="col-md-4">md-4</div>
<div class="col-md-4">md-4</div>
</div>
<div class="row">
<div class="col col-md-6">md-6</div>
<div class="col col-md-6">md-6</div>
<div class="col-md-6">md-6</div>
<div class="col-md-6">md-6</div>
</div>
{% endexample %}
</div>
@ -305,21 +305,21 @@ Don't want your columns to simply stack in smaller devices? Use the extra small
{% example html %}
<!-- Stack the columns on mobile by making one full-width and the other half-width -->
<div class="row">
<div class="col col-xs-12 col-md-8">.col .col-xs-12 .col-md-8</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col-xs-12 col-md-8">.col-xs-12 .col-md-8</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<!-- Columns start at 50% wide on mobile and bump up to 33.3% wide on desktop -->
<div class="row">
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<!-- Columns are always 50% wide, on mobile and desktop -->
<div class="row">
<div class="col col-xs-6">.col .col-xs-6</div>
<div class="col col-xs-6">.col .col-xs-6</div>
<div class="col-xs-6">.col-xs-6</div>
<div class="col-xs-6">.col-xs-6</div>
</div>
{% endexample %}
</div>
@ -331,15 +331,15 @@ Build on the previous example by creating even more dynamic and powerful layouts
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-xs-12 col-sm-6 col-md-8">.col-xs-12 .col-sm-6 .col-md-8</div>
<div class="col col-xs-6 col-md-4">.col .col-xs-6 .col-md-4</div>
<div class="col-xs-12 col-sm-6 col-md-8">.col-xs-12 .col-sm-6 .col-md-8</div>
<div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<div class="row">
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
<!-- Optional: clear the XS cols if their content doesn't match in height -->
<div class="clearfix hidden-sm-up"></div>
<div class="col col-xs-6 col-sm-4">.col .col-xs-6 .col-sm-4</div>
<div class="col-xs-6 col-sm-4">.col-xs-6 .col-sm-4</div>
</div>
{% endexample %}
</div>
@ -351,9 +351,9 @@ If more than 12 columns are placed within a single row, each group of extra colu
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-xs-9">.col .col-xs-9</div>
<div class="col col-xs-4">.col .col-xs-4<br>Since 9 + 4 = 13 &gt; 12, this 4-column-wide div gets wrapped onto a new line as one contiguous unit.</div>
<div class="col col-xs-6">.col .col-xs-6<br>Subsequent columns continue along the new line.</div>
<div class="col-xs-9">.col-xs-9</div>
<div class="col-xs-4">.col-xs-4<br>Since 9 + 4 = 13 &gt; 12, this 4-column-wide div gets wrapped onto a new line as one contiguous unit.</div>
<div class="col-xs-6">.col-xs-6<br>Subsequent columns continue along the new line.</div>
</div>
{% endexample %}
</div>
@ -365,14 +365,14 @@ With the four tiers of grids available you're bound to run into issues where, at
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
<!-- Add the extra clearfix for only the required viewport -->
<div class="clearfix hidden-sm-up"></div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col col-xs-6 col-sm-3">.col .col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
<div class="col-xs-6 col-sm-3">.col-xs-6 .col-sm-3</div>
</div>
{% endexample %}
</div>
@ -382,13 +382,13 @@ In addition to column clearing at responsive breakpoints, you may need to **rese
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-sm-5 col-md-6">.col .col-sm-5 .col-md-6</div>
<div class="col col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col .col-sm-5 .offset-sm-2 .col-md-6 .offset-md-0</div>
<div class="col-sm-5 col-md-6">.col-sm-5 .col-md-6</div>
<div class="col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col-sm-5 .offset-sm-2 .col-md-6 .offset-md-0</div>
</div>
<div class="row">
<div class="col col-sm-6 col-md-5 col-lg-6">.col.col-sm-6.col-md-5.col-lg-6</div>
<div class="col col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col .col-sm-6 .col-md-5 .offset-md-2 .col-lg-6 .offset-lg-0</div>
<div class="col-sm-6 col-md-5 col-lg-6">.col.col-sm-6.col-md-5.col-lg-6</div>
<div class="col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col-sm-6 .col-md-5 .offset-md-2 .col-lg-6 .offset-lg-0</div>
</div>
{% endexample %}
</div>
@ -400,15 +400,15 @@ Move columns to the right using `.offset-md-*` classes. These classes increase t
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-md-4">.col-md-4</div>
<div class="col col-md-4 offset-md-4">.col-md-4 .offset-md-4</div>
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4 offset-md-4">.col-md-4 .offset-md-4</div>
</div>
<div class="row">
<div class="col col-md-3 offset-md-3">.col .col-md-3 .offset-md-3</div>
<div class="col col-md-3 offset-md-3">.col .col-md-3 .offset-md-3</div>
<div class="col-md-3 offset-md-3">.col-md-3 .offset-md-3</div>
<div class="col-md-3 offset-md-3">.col-md-3 .offset-md-3</div>
</div>
<div class="row">
<div class="col col-md-6 offset-md-3">.col .col-md-6 .offset-md-3</div>
<div class="col-md-6 offset-md-3">.col-md-6 .offset-md-3</div>
</div>
{% endexample %}
</div>
@ -420,14 +420,14 @@ To nest your content with the default grid, add a new `.row` and set of `.col-sm
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-sm-9">
Level 1: .col .col-sm-9
<div class="col-sm-9">
Level 1: .col-sm-9
<div class="row">
<div class="col col-xs-8 col-sm-6">
Level 2: .col .col-xs-8 .col-sm-6
<div class="col-xs-8 col-sm-6">
Level 2: .col-xs-8 .col-sm-6
</div>
<div class="col col-xs-4 col-sm-6">
Level 2: .col .col-xs-4 .col-sm-6
<div class="col-xs-4 col-sm-6">
Level 2: .col-xs-4 .col-sm-6
</div>
</div>
</div>
@ -442,8 +442,8 @@ Easily change the order of our built-in grid columns with `.col-md-push-*` and `
<div class="bd-example-row">
{% example html %}
<div class="row">
<div class="col col-md-9 push-md-3">.col .col-md-9 .push-md-3</div>
<div class="col col-md-3 pull-md-9">.col .col-md-3 .pull-md-9</div>
<div class="col-md-9 push-md-3">.col-md-9 .push-md-3</div>
<div class="col-md-3 pull-md-9">.col-md-3 .pull-md-9</div>
</div>
{% endexample %}
</div>

View file

@ -36,16 +36,16 @@
// Common styles for small and large grid columns
@if $enable-grid-classes {
.col {
[class^="col"] {
position: relative;
min-height: 1px;
padding-right: ($grid-gutter-width / 2);
padding-left: ($grid-gutter-width / 2);
// Allow `.col` to use an automatic, even width when flex mode is enabled
@if $enable-flex {
flex: 1;
}
//
// // Allow `.col` to use an automatic, even width when flex mode is enabled
// @if $enable-flex {
// flex: 1;
// }
}
@include make-grid-columns();

View file

@ -9,14 +9,22 @@
$breakpoint-counter: ($breakpoint-counter + 1);
@include media-breakpoint-up($breakpoint, $breakpoints) {
// Work around cross-media @extend (https://github.com/sass/sass/issues/1050)
%grid-column-float-#{$breakpoint} {
float: left;
// %grid-column-float-#{$breakpoint} {
// float: left;
// }
@if $enable-flex {
.col-#{$breakpoint} {
@include make-col($gutter);
flex-basis: 0;
flex-grow: 1;
max-width: 100%;
}
}
@for $i from 1 through $columns {
.col-#{$breakpoint}-#{$i} {
@if not $enable-flex {
@extend %grid-column-float-#{$breakpoint};
}
// @if not $enable-flex {
// @extend %grid-column-float-#{$breakpoint};
// }
@include make-col-span($i, $columns);
}
}

View file

@ -35,17 +35,25 @@
@mixin make-col($gutter: $grid-gutter-width) {
position: relative;
@if $enable-flex {
flex: 1;
} @else {
float: left;
}
// @if $enable-flex {
// flex: 1;
// } @else {
// float: left;
// }
min-height: 1px;
padding-left: ($gutter / 2);
padding-right: ($gutter / 2);
}
@mixin make-col-span($size, $columns: $grid-columns) {
position: relative;
@if $enable-flex {
flex: 0 0 auto;
}
min-height: 1px;
padding-left: ($grid-gutter-width / 2);
padding-right: ($grid-gutter-width / 2);
@if $enable-flex {
flex: 0 0 percentage($size / $columns);
// Add a `max-width` to ensure content within each column does not blow out
@ -53,6 +61,7 @@
// do not appear to require this.
max-width: percentage($size / $columns);
} @else {
float: left;
width: percentage($size / $columns);
}
}