You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1191 lines
66 KiB

5 years ago
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Reflex grid - a lightweight responsive flexbox grid with cross browser support, an inline-block fallback and no polyfills.</title>
<meta name="description" content="reflex is a responsive flexbox grid with inline-block legacy support and no polyfills">
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=yes" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link rel="stylesheet" href="css/docs.css">
<script src="js/respond.min.js"></script>
<script src="js/html5shiv.js"></script>
</head>
<body>
<header role="banner" class="container">
<h1><img class="logo" width="50" height="50" src=""> Reflex grid</h1>
<p>A lightweight responsive flexbox grid with cross browser support, an inline-block fallback and no polyfills.</p>
<nav>
<p>
Interested? Check out the code on <a href="https://github.com/leejordan/reflex" target="_blank">github</a>, grab the <a href="https://raw.githubusercontent.com/leejordan/reflex/master/css/reflex.css">css</a> directly, look at some <a href="examples.html">examples</a>, or keep reading to learn more.
</p>
</nav>
</header>
<main role="main" class="documentation">
<article>
<section id="toc" class="container" role="contents"></section>
<section class="container">
<h2 id="what-is-reflex">Introduction <a href="#what-is-reflex">&#35;</a></h2>
<p>Reflex gives you the ability to take advantage of flexbox for laying out a grid while having a reliable inline-block fallback for older browsers.</p>
<div class="grid">
<div class="col-6">
<p>Look at me!</p>
</div>
<div class="col-6">
<p>I am a Reflex grid!</p>
</div>
</div>
<p>At the time of writing, <a href="http://caniuse.com/#search=flex" target="_blank">browser flexbox support is at 96.63%</a> so it's definitely time to forge ahead with flexbox, especially with a reliable inline-block fallback. Where flexbox isn't supported, your basic grid structure will remain intact and most of the layout classes still work. Try this page out in a browser that does not support flexbox (such as Internet Explorer 9) to see for yourself!
<p>The reason this works is because of the way browsers handle CSS properties that they do not understand. It's possible to include both your fallback and your ideal CSS properties in the same classes and let browsers use the ones that they do understand. I've <a href="http://lendmeyourear.net/layering-css-so-we-can-use-flexbox-now.html">written at length on this subject</a> if you're interested in learning more.</p>
<p class="alert">This is version 2 of Reflex grid which is not compatible with version 1. The last release under version 1 was <a href="https://github.com/leejordan/reflex/tree/1.5.0">1.5.0</a> and I have maintained the <a href="v1">docs for version 1</a> in case you still need them.</p>
<h3 id="reflex-benefits">Why use reflex? <a href="#reflex-benefits">&#35;</a></h3>
<ul>
<li>It's lightweight - 20KB in it's minified form and <strong>2.5KB gzipped</strong></li>
<li>Where flexbox is supported, <strong>columns are all the same height by default</strong></li>
<li>Reflex grid cells <strong>never push each other out of the way</strong> (as with floated grids)</li>
<li>Supports semantic elements e.g. you can use <code>ul</code> as a grid</li>
<li>Supports nested grids</li>
<li>Good cross browser support</li>
<li>Built with <a href="http://sass-lang.com/" target="_blank">Sass/SCSS</a></li>
<li>Easily customizable and extendable</li>
</ul>
<h3 id="intended-use">Intended use <a href="#intended-use">&#35;</a></h3>
<ul>
<li>Creating complex nested flexbox grids which take advantage of flexbox layout properties</li>
<li>Using a flexbox layout inside a <a href="https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Grid_Layout">CSS grid</a> page layout</li>
<li>Generating a flexbox grid with dynamic content of varying height e.g. a list of products</li>
<li>An addition or replacement for your current css layout framework</li>
<li>A set of vendor-prefixed mixins and helper classes to get your flexbox solution off the ground faster</li>
</ul>
</section>
<section class="container">
<h2 id="browser-support">Browser support <a href="#browser-support">&#35;</a></h2>
<p>All browser specific implementations of flexbox are supported via vendor prefixes, including the slightly problematic <a href="https://msdn.microsoft.com/en-us/library/hh673531(v=vs.85).aspx">IE10 implementation</a> of an early draft of the flexbox specification. Internet Explorer 6 and 7 are explicitly not supported because there are so many issues and quirks that it renders the exercise futile. However, the basic grid still works in those browsers.</p>
<h3 id="ie8-breakpoints">Breakpoints in ie8 <a href="#ie8-breakpoints">&#35;</a></h3>
<p>If you want to use the grid with breakpoints in ie8 you will need to use <a href="https://github.com/scottjehl/Respond" target="_blank">respond.js</a> which enables media query support in those browsers via JavaScript. There's very little downside to adding this because it's very lightweight and performs well.</p>
<h3 id="html5-elements">HTML5 elements <a href="#html5-elements">&#35;</a></h3>
<p>If you wish to use html5 elements such as <code>section</code> in older browsers such as ie8 and 9, you will need to use <a href="https://github.com/afarkas/html5shiv" target="_blank">html5Shiv</a>. Again, there's very little downside to using this considering the extra peace of mind it gives you when using html5 elements.</p>
<h3 id="ie10-11-height">ie10 and ie11 grid heights <a href="#ie10-11-height">&#35;</a></h3>
<p>ie10 and ie11 have a flexbox rendering bug which means that unless the height of the grid is set with an unit value, flex items will only stretch to be as large as their largest sibling. The grid will still work in these browsers, but it won't entirely fill the height of it's container unless a <code>height</code> in units is specified for the grid.</p>
<p>Please note that <code>min-height</code> and percentage heights will not work. The height must be set with <code>px</code> <code>em</code> or <code>vh</code>. There's <a href="https://philipwalton.com/articles/normalizing-cross-browser-flexbox-bugs/">further reading</a> to be had on the bug itself if you wish to understand it further. You can use a <a href="https://philipnewcomer.net/2014/04/target-internet-explorer-10-11-css/">CSS hack for ie10 and ie11</a> to set a unit height and solve these issues in your grid implementation.</p>
<pre>.grid {
min-height: 300px;
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
height: 600px;
}
}</pre>
<h3 id="border-box">box-sizing: border-box <a href="#border-box">&#35;</a></h3>
<p>I highly recommend using a wildcard CSS query to set all elements to <code>box-sizing: border-box</code>. Reflex grid applies this to all grid elements so it is sized appropriately but you might want to also add these properties to your CSS framework to ensure consistent behaviour across all elements inside and outside of the grid:</p>
<pre>*, *::after, *::before {
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}</pre>
</section>
<section class="container">
<h2 id="usage">Usage <a href="#usage">&#35;</a></h2>
<h3 id="use-css">Use as CSS <a href="#use-css">&#35;</a></h3>
<p>You can use the compiled css directly by downloading either the <a href="https://raw.githubusercontent.com/leejordan/reflex/master/css/reflex.min.css">minified</a> or <a href="https://raw.githubusercontent.com/leejordan/reflex/master/css/reflex.css">non-minified</a> version.</p>
<h3 id="use-git">Clone via github <a href="#use-git">&#35;</a></h3>
<p>You could clone this repo via <a href="https://github.com/leejordan/reflex">github</a> which would allow you to modify the variables and build your own version of this grid. You can modify things like the number of columns or the breakpoints.</p>
<h3 id="use-npm">Use with npm <a href="#use-npm">&#35;</a></h3>
<p>If you're familiar with npm you can use <code>npm install reflex-grid</code> to have a look around, or add it as a dependency to your node project.</p>
<p>Visit the <a href="https://www.npmjs.com/package/reflex-grid">reflex-grid npm page</a> for stats and other npm related info.</p>
</section>
<section class="container">
<h2 id="flexbox-introduction">Flexbox direction and axis <a href="#flexbox-introduction">&#35;</a></h2>
<p>
To understand how this grid works, you'll need to first understand how flexbox works, especially in relation to the cross axis and main axis. There's a pretty good <a href="https://css-tricks.com/snippets/css/a-guide-to-flexbox/" target="_blank">introduction to flexbox here</a>.
</p>
<p>In a nutshell, any direct child elements of a flexbox container are treated as flex items and can be layed out with flexbox css properties on either axis.</p>
<p>By default any <code>grid</code> element is set to <code>flex-direction: row</code> and the main axis therefore follows the horizontal direction.</p>
<p>You can optionally set any <code>col-x</code> element to operate as a flex container using the class <code>col-grid</code> which sets <code>flex-direction: column</code> and the main axis therefore follows the vertical direction. There's more information on this in the <a href="#flex-columns">Using flexbox in columns</a> section.</p>
</section>
<section class="container">
<h2 id="grid-introduction">Anatomy of a reflex grid <a href="#grid-introduction">&#35;</a></h2>
<h3 id="basic-example">Basic example <a href="#basic-example">&#35;</a></h3>
<p class="alert">I have added some colour as a visual indicator to all the examples on this page so you can clearly see how the layout works. This is just for demonstration purposes.</p>
<pre>&lt;div class="grid"&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
<div class="grid">
<div class="col-6">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc et sagittis dui. Maecenas rhoncus justo aliquam urna finibus tincidunt et ut mauris.</p>
</div>
<div class="col-6">
<p>Vivamus nulla leo, dignissim nec tempor vel, consequat ac dolor. Nunc dignissim in ante sed dapibus. Aenean sit amet aliquet dolor, at auctor erat.</p>
</div>
</div>
<h3 id="closer-look">A closer look <a href="#closer-look">&#35;</a></h3>
<h4>grid parent</h4>
<p>example: <code>grid</code></p>
<p>
This is the top level container element and is similar to a <code>row</code> in bootstrap. Any <code>.col</code> element that is a direct child of a <code>.grid</code> is a flex item and their layout can be affected by any modifer classes placed on the parent <code>.grid</code>.
<h4>column child</h4>
<p>examples: <code>col-10</code> <code>col-sm-6</code> <code>col-auto</code></p>
<p>
This is a child element of <code>.grid</code> and behaves as a flex item.
</p>
<h4>grid modifier</h4>
<p>examples: <code>align-end</code> <code>no-wrap</code> <code>justify-center</code></p>
<p>
Modifier classes can be applied to the <code>.grid</code> element to modify the layout of it's direct children elements.
</p>
</section>
<section class="container">
<h2 id="semantic-markup">Semantic markup <a href="#semantic-markup">&#35;</a></h2>
<p>You don't have to use <code>div</code> for your grid and ideally you should use the most semantically appropriate markup for your use case with no visible difference.</p>
<h3 id="using-divs">Divs <a href="#using-divs">&#35;</a></h3>
<pre>&lt;div class="grid"&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
<h3 id="using-list">Unordered list <a href="#using-list">&#35;</a></h3>
<pre>&lt;ul class="grid"&gt;
&lt;li class="col-6"&gt;
&lt;content&gt;
&lt;/li&gt;
&lt;/ul&gt;</pre>
<h3 id="using-html5">Html5 elements <a href="#using-html5">&#35;</a></h3>
<pre>&lt;section class="grid"&gt;
&lt;article class="col-6"&gt;
&lt;content&gt;
&lt;/article&gt;
&lt;/section&gt;</pre>
</section>
<section class="container">
<h2 id="breakpoints">Numbered columns <a href="#breakpoints">&#35;</a></h2>
<p>By default reflex is a 12 column grid but this can be easily changed. Regardless of how many columns you need, you will likely require extra control over the breakpoints at which your grid columns revert to 100% width. To do this you will need to use these modifier classes which determine grid columns at various viewport sizes. A grid built using numbered columns in this way will remain fully intact in the inline-block fallback.</p>
<p>The reflex grid breakpoints can be easily re-defined but are set to these values by default:</p>
<dl>
<dt>col-</dt>
<dd>does not collapse</dd>
<dt>col-xs-</dt>
<dd>collapses below 576px</dd>
<dt>col-sm-</dt>
<dd>collapses below 768px</dd>
<dt>col-md-</dt>
<dd>collapses below 992px</dd>
<dt>col-lg-</dt>
<dd>collapses below 1200px</dd>
<dt>col-xlg-</dt>
<dd>collapses below 1600px</dd>
</dl>
<div class="grid">
<div class="col-4">
<p>col-4</p>
</div>
<div class="col-4">
<p>col-4</p>
</div>
<div class="col-4">
<p>col-4</p>
</div>
<div class="col-xs-4">
<p>col-xs-4</p>
</div>
<div class="col-xs-8">
<p>col-xs-8</p>
</div>
<div class="col-sm-6">
<p>col-sm-6</p>
</div>
<div class="col-sm-6">
<p>col-sm-6</p>
</div>
<div class="col-md-8">
<p>col-md-8</p>
</div>
<div class="col-md-4">
<p>col-md-4</p>
</div>
<div class="col-lg-4">
<p>col-lg-4</p>
</div>
<div class="col-lg-8">
<p>col-lg-8</p>
</div>
<div class="col-xlg-8">
<p>col-xlg-8</p>
</div>
<div class="col-xlg-4">
<p>col-xlg-4</p>
</div>
</div>
</section>
<section class="container">
<h2 id="auto-grid">Auto columns <a href="#auto">&#35;</a></h2>
<p>You can add any number of auto sizing <code>col-auto</code> columns to a <code>grid</code> and therefore avoid using numbered columns. You can also use the breakpoint sensitive classes such as <code>col-sm-auto</code> to determine when your columns revert to 100% width. A grid built using auto columns will not remain fully intact in the inline-block fallback. For full browser support, you need to use numbered columns.</p>
<div class="grid">
<div class="col-auto">
col-auto
</div>
<div class="col-auto">
col-auto
</div>
<div class="col-sm-auto">
col-sm-auto
</div>
<div class="col-md-auto">
col-md-auto
</div>
<div class="col-lg-auto">
col-lg-auto
</div>
<div class="col-xlg-auto">
col-xlg-auto
</div>
</div>
</section>
<section class="container">
<h2 id="containers">Containers <a href="#containers">&#35;</a></h2>
<p>A Reflex grid will fill the full width of it's parent element which means you can drop it into any containing element you may already have in place.</p>
<p>However, Reflex grid has a responsive <code>.container</code> class available which uses a combination of margins and padding to maintain layout between elements both inside and outside of the grid. By default this uses the same breakpoints as the <a href="#breakpoints">numbered columns</a>. However, It is possible to modify the max width and breakpoints of the <code>.container</code> class by modifying the included variables.scss file and building a new css file.</p>
<h3 id="responsive-container">Responsive container <a href="#responsive-container">&#35;</a></h3>
<pre>&lt;div class="container"&gt;
&lt;p&gt;This element is inside the container but outside of the grid&lt;/p&gt;
&lt;div class="grid"&gt;
&lt;div class="col-6"&gt;
&lt;p&gt;An element inside the grid&lt;/p&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;p&gt;Another element inside the grid&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
</section>
<div class="container">
<p>This element is inside the container but outside of the grid</p>
<div class="grid">
<div class="col-6">
<p>An element inside the grid</p>
</div>
<div class="col-6">
<p>Another element inside the grid</p>
</div>
</div>
</div>
<div class="container">
<h3 id="full-container">Full width container <a href="#full-container">&#35;</a></h3>
<p>If you desire a full width container without a max width but with the same combination of margins and padding to maintain layout between elements both inside and outside of the grid there is also a <code>.container-full</code> class available.</p>
<pre>&lt;div class="container-full"&gt;
&lt;p&gt;This element is inside the &lt;em&gt;full width&lt;/em&gt; container but outside of the grid&lt;/p&gt;
&lt;div class="grid"&gt;
&lt;div class="col-6"&gt;
&lt;p&gt;An element inside the grid&lt;/p&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;p&gt;Another element inside the grid&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
</div>
<div class="container-full">
<p>This element is inside the <em>full width</em> container but outside of the grid</p>
<div class="grid">
<div class="col-6">
<p>An element inside the grid</p>
</div>
<div class="col-6">
<p>Another element inside the grid</p>
</div>
</div>
</div>
<div class="container">
<h3 id="no-container">No container <a href="#no-container">&#35;</a></h3>
<p>Without a container, the grid fills it's containing element (in this case the <code>body</code> element).</p>
</div>
<div class="grid">
<div class="col-6">
<p>An element inside the grid</p>
</div>
<div class="col-6">
<p>Another element inside the grid</p>
</div>
</div>
<section class="container">
<h2 id="nested-grids">Nested grids <a href="#nested-grids">&#35;</a></h2>
<p>It's possible to nest grids inside each other. Start a new <code>.grid</code> inside a <code>.col-x</code> element and everything lines up correctly. There are some more advanced examples of layouts on the <a href="examples.html">examples page</a>.</p>
<pre>&lt;div class="grid"&gt;
&lt;div class="col-sm-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;div class="col-sm-6"&gt;
&lt;div class="grid"&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;div class="col-6"&gt;
&lt;content&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
<div class="grid">
<div class="col-sm-6">
<p>col-sm-6</p>
</div>
<div class="col-sm-6">
<div class="grid">
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-6">
<p>col-6</p>
</div>
</div>
</div>
</div>
</section>
<section class="container">
<h2 id="grid-wrap">Grid wrapping <a href="#grid-wrap">&#35;</a></h2>
<p>By default, the <code>flex-wrap</code> property of a <code>display: flex</code> element is set to <code>nowrap</code> but because this is a grid framework we generally need our grid to wrap so we explcitly set <code>flex-wrap: wrap</code> on our <code>grid</code> element</p>
<p class="alert">In the inline-block fallback your grid columns will always wrap when they add up to 100% width (12 column by default).</p>
<h4 id="wrap">default wrap <a href="#wrap">&#35;</a></h4>
<p>Grid columns wrap by default.</p>
<div class="grid">
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-10">
<p>col-10</p>
</div>
</div>
<h4 id="no-wrap">.no-wrap <a href="#no-wrap">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>flex-wrap: nowrap</code> and gives you this:</p>
<div class="grid no-wrap">
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-6">
<p>col-6</p>
</div>
<div class="col-10">
<p>col-10</p>
</div>
</div>
<h4 id="wrap-reverse">.wrap-reverse <a href="#wrap-reverse">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>flex-wrap: wrap-reverse</code> and gives you a grid that wraps in reverse:</p>
<div class="grid wrap-reverse">
<div class="col-6">
<p>col-6 (I am first in the markup)</p>
</div>
<div class="col-6">
<p>col-6 (I am second in the markup)</p>
</div>
<div class="col-10">
<p>col-10 (I am third in the markup)</p>
</div>
</div>
</section>
<section class="container">
<h2 id="cross-axis-alignment">Cross axis modifiers <a href="#cross-axis-alignment">&#35;</a></h2>
<p>These modifiers can be added to your <code>grid</code> element.</p>
<h4 id="equal-height-columns">Equal height columns by default <a href="#equal-height-columns">&#35;</a></h4>
<p>In browsers that support flexbox we have equal height columns by default because the default value of <code>align-items</code> is <code>stretch</code></p>
<div class="grid">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Over after behold was living together tree is very sixth let bring fish. Forth behold they're fly deep.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first.</p>
</div>
</div>
<h4 id="align-start">.align-start <a href="#align-start">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-items: flex-start</code> and gives you this:</p>
<div class="grid align-start">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Over after behold was living together tree is very sixth let bring fish. Forth behold they're fly deep.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first.</p>
</div>
</div>
<h4 id="align-end">.align-end <a href="#align-end">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-items: flex-end</code></p>
<div class="grid align-end">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Over after behold was living together tree is very sixth let bring fish. Forth behold they're fly deep.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first.</p>
</div>
</div>
<h4 id="align-center">.align-center <a href="#align-center">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-items: center</code></p>
<div class="grid align-center">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Over after behold was living together tree is very sixth let bring fish. Forth behold they're fly deep.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first.</p>
</div>
</div>
<h4 id="align-baseline">.align-baseline <a href="#align-baseline">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-items: baseline</code>. This makes <code>col-x</code> elements line up according to the baseline of the first child element (as long as the first elements in each column are an inline element such as headings or paragraphs). This example should make this confusing behaviour a bit clearer:</p>
<div class="grid align-baseline">
<div class="col-4">
<p style="font-size: 32px; font-size: 2rem;">Biggest text</p>
</div>
<div class="col-4">
<p style="font-size: 24px; font-size: 1.5rem;">Medium text</p>
</div>
<div class="col-4">
<p>Small text</p>
</div>
</div>
</section>
<section class="container">
<h2 id="cross-axis-align-override">Cross axis override modifiers <a href="#cross-axis-align-override">&#35;</a></h2>
<p>You can override the cross axis alignment of a single <code>col-x</code> element by using these modifers.</p>
<h4 id="align-self-stretch">.align-self-stretch <a href="#align-self-stretch">&#35;</a></h4>
<p>When applied to <code>col-x</code> sets <code>align-self: stretch</code></p>
<div class="grid align-start">
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good.</p>
</div>
<div class="col-4 align-self-stretch">
<p>.align-self-stretch</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good Created rule image night firmament.</p>
</div>
</div>
<h4 id="align-self-start">.align-self-start <a href="#align-self-start">&#35;</a></h4>
<p>When applied to <code>col-x</code> sets <code>align-self: flex-start</code></p>
<div class="grid">
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good.</p>
</div>
<div class="col-4 align-self-start">
<p>.align-self-start</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good Created rule image night firmament.</p>
</div>
</div>
<h4 id="align-self-end">.align-self-end <a href="#align-self-end">&#35;</a></h4>
<p>When applied to <code>col-x</code> sets <code>align-self: flex-end</code></p>
<div class="grid">
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good.</p>
</div>
<div class="col-4 align-self-end">
<p>align-self-end</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good Created rule image night firmament.</p>
</div>
</div>
<h4 id="align-self-center">.align-self-center <a href="#align-self-center">&#35;</a></h4>
<p>When applied to <code>col-x</code> sets <code>align-self: center</code></p>
<div class="grid">
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good.</p>
</div>
<div class="col-4 align-self-center">
<p>align-self-center</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule that bring fly gathered there is place good Created rule image night firmament.</p>
</div>
</div>
</section>
<section class="container">
<h2 id="cross-axis-position">Cross axis positioning <a href="#cross-axis-position">&#35;</a></h2>
<p>These modifers set the value of <code>align-content</code> which determine the position of your grid elements when there is extra space available in the cross-axis (usually because you've set a height on the grid that is larger than the contents). These modifiers can be added to your <code>grid</code> element but also to the <code>col-x</code> elements inside the grid.</p>
<p class="alert">This modifier has no effect when there is only one line of <code>col-x</code> elements in the grid so cannot be used when <code>no-wrap</code> is present on the grid or when you only have a single row of columns</p>
<h4 id="align-content-default">Stretch by default <a href="#align-content-default">&#35;</a></h4>
<p>In browsers that support flexbox we have equal height columns that stretch to fill the available space by default because the default value of <code>align-content</code> is <code>stretch</code></p>
<div class="grid">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good</p>
</div>
</div>
<h4 id="align-content-start">.align-content-start <a href="#align-content-start">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-content: flex-start</code></p>
<div class="grid align-content-start">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good</p>
</div>
</div>
<h4 id="align-content-end">.align-content-end <a href="#align-content-end">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-content: flex-end</code></p>
<div class="grid align-content-end">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good</p>
</div>
</div>
<h4 id="align-content-center">.align-content-center <a href="#align-content-center">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-content: center</code></p>
<div class="grid align-content-center">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good </p>
</div>
</div>
<h4 id="align-content-space-between">.align-content-space-between <a href="#align-content-space-between">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-content: space-between</code></p>
<div class="grid align-content-space-between">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good</p>
</div>
</div>
<h4 id="align-content-space-around">.align-content-space-around <a href="#align-content-space-around">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>align-content: space-around</code></p>
<div class="grid align-content-space-around">
<div class="col-4">
<p>First appear</p>
</div>
<div class="col-4">
<p>Great blessed</p>
</div>
<div class="col-4">
<p>Years night</p>
</div>
<div class="col-4">
<p>Firmament you</p>
</div>
<div class="col-4">
<p>To lights</p>
</div>
<div class="col-4">
<p>Place good</p>
</div>
</div>
</section>
<section class="container">
<h2 id="main-axis-alignment">Main axis alignment <a href="#main-axis-alignment">&#35;</a></h2>
<p>These modifers set the value of <code>justify-content</code> which determine the position of your grid elements when there is extra space available in the main-axis (usually because your columns do not make up the full width of a grid). These modifiers can be added to your <code>grid</code> element but also to the <code>col-x</code> elements inside the grid.</p>
<h4 id="default-main-axis">Left aligned by default <a href="#default-main-axis">&#35;</a></h4>
<p>Grid elements are aligned to the left by default because the default value of <code>justify-content</code> is <code>flex-start</code></p>
<div class="grid">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
</div>
<h4 id="justify-end">.justify-end <a href="#justify-end">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>justify-content: flex-end</code></p>
<div class="grid justify-end">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
</div>
<h4 id="justify-center">.justify-center <a href="#justify-center">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>justify-content: center</code></p>
<div class="grid justify-center">
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
</div>
<h4 id="justify-space-between">.justify-space-between <a href="#justify-space-between">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>justify-content: space-between</code></p>
<div class="grid justify-space-between">
<div class="col-3">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
<div class="col-3">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
</div>
<h4 id="justify-space-around">.justify-space-around <a href="#justify-space-around">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>justify-content: space-around</code></p>
<div class="grid justify-space-around">
<div class="col-3">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
<div class="col-3">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>First appear years night there the in them rule.</p>
</div>
<div class="col-4">
<p>Be can't winged good for also saying first. Shall, fourth Greater cattle.</p>
</div>
</div>
</section>
<section class="container">
<h3 id="flex-direction">Flex direction <a href="#flex-direction">&#35;</a></h3>
<p>These modifers set the value of <code>flex-direction</code>. These modifiers can be added to your <code>grid</code> element but also to the <code>col-x</code> elements inside the grid.</p>
<h4 id="rows-by-default">Rows by default <a href="#rows-by-default">&#35;</a></h4>
<p><code>grid</code> elements are in rows by default because the default value of <code>flex-direction</code> is <code>row</code>. <code>col-x</code> elements are columns by default but can be set to behave as rows by using <code>direction-row</code></p>
<div class="grid">
<div class="col-4">
<p>I am <strong>first</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>second</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>third</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>fourth</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>fifth</strong> in the markup</p>
</div>
</div>
<h4 id="direction-row-reverse">.direction-row-reverse <a href="#direction-row-reverse">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>flex-direction: row-reverse</code></p>
<div class="grid direction-row-reverse">
<div class="col-4">
<p>I am <strong>first</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>second</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>third</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>fourth</strong> in the markup</p>
</div>
<div class="col-4">
<p>I am <strong>fifth</strong> in the markup</p>
</div>
</div>
<h4 id="direction-column">.direction-column <a href="#direction-column">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>flex-direction: column</code></p>
<div class="grid direction-column">
<div class="col-9">
<p>I am <strong>first</strong> in the markup</p>
</div>
<div class="col-10">
<p>I am <strong>second</strong> in the markup</p>
</div>
<div class="col-7">
<p>I am <strong>third</strong> in the markup</p>
</div>
</div>
<h4 id="direction-column-reverse">.direction-column-reverse <a href="#direction-column-reverse">&#35;</a></h4>
<p>When applied to <code>grid</code> sets <code>flex-direction: column-reverse</code></p>
<div class="grid direction-column-reverse">
<div class="col-9">
<p>I am <strong>first</strong> in the markup</p>
</div>
<div class="col-10">
<p>I am <strong>second</strong> in the markup</p>
</div>
<div class="col-7">
<p>I am <strong>third</strong> in the markup</p>
</div>
</div>
</section>
<section class="container">
<h2 id="ordering">Ordering grid elements <a href="#ordering">&#35;</a></h2>
<p>These helper classes allow you to easily set <code>order</code> to your grid elements. This is useful because it allows you to have your markup in the correct semantic order for accessiblity purposes but in a different order visually.</p>
<p>By default there are 12 ordering helpers to match the default 12 columns. Changing the number of columns by editing the variable will also produce a matching number of order helper classes</p>
<h3 id="order">.order-<em>&lt;n&gt;</em> <a href="#order">&#35;</a></h3>
<p>When applied to <code>col-x</code> sets <code>order: n</code></p>
<div class="grid">
<div class="col-4 order-2">
<p>I am <strong>first</strong> in the markup but ordered second</p>
</div>
<div class="col-4 order-3">
<p>I am <strong>second</strong> in the markup but ordered third</p>
</div>
<div class="col-4 order-1">
<p>I am <strong>third</strong> in the markup but ordered first</p>
</div>
</div>
</section>
<section class="container">
<h2 id="responsive-ordering">Responsive ordering <a href="#responsive-ordering">&#35;</a></h2>
<p>There are responsive ordering classes that correspond to both the number of columns and the <a href="#breakpoints">breakpoints</a> so you can choose to change the order of <code>col-x</code> elements only above certain viewport sizes.</p>
<p>For example: <code>.order-md-2</code></p>
<h3 id="order-responsive">.order-<em>&lt;breakpoint&gt;</em>-<em>&lt;n&gt;</em> <a href="#order-responsive">&#35;</a></h3>
<p>When applied to <code>col-x</code> sets <code>order: n</code> when viewport size is above the selected breakpoint.</p>
<div class="grid">
<div class="col-4 order-md-2">
<p>I am <strong>first</strong> in the markup but ordered second when viewport size is above 992px</p>
</div>
<div class="col-4 order-md-3">
<p>I am <strong>second</strong> in the markup but ordered third when viewport size is above 992px</p>
</div>
<div class="col-4 order-md-1">
<p>I am <strong>third</strong> in the markup but ordered first when viewport size is above 992px</p>
</div>
</div>
</section>
<section class="container">
<h2 id="offet-columns">Responsive offsets <a href="#offet-columns">&#35;</a></h2>
<p>There are responsive offset classes that correspond to the available <a href="#breakpoints">breakpoints</a> so you can choose to offset your <code>col-x</code> elements at certain viewport sizes.</p>
<p>For example: <code>.offset-md-2</code></p>
<h3 id="offset">.offset-<em>&lt;breakpoint&gt;</em>-<em>&lt;n&gt;</em> <a href="#offset">&#35;</a></h3>
<p>When applied to <code>col-x</code> applies an offset when viewport size is above the selected breakpoint.</p>
<div class="grid">
<div class="col-6 offset-3">
<p>Offset by 3 columns at all times</p>
</div>
<div class="col-6 offset-md-2">
<p>Offset by 2 columns when viewport size is above 768px</p>
</div>
<div class="col-6 offset-lg-1">
<p>Offset by 1 column when viewport size is above 1200px</p>
</div>
</div>
</section>
<section class="container">
<h2 id="padding-modifiers">Padding modifiers <a href="#padding-modifiers">&#35;</a></h2>
<p>By default, <code>col-x</code> columns have internal padding. It's possible to remove this padding on the entire grid or single columns.</p>
<h3 id="grid-bleed">.grid-bleed <a href="#grid-bleed">&#35;</a></h3>
<p>When used on a <code>.grid</code> element, removes internal padding from all child <code>col-x</code> column elements.</p>
<div class="grid grid-bleed">
<div class="col-6">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc et sagittis dui. Maecenas rhoncus justo aliquam urna finibus tincidunt et ut mauris.</p>
</div>
<div class="col-6">
<p>Vivamus nulla leo, dignissim nec tempor vel, consequat ac dolor. Nunc dignissim in ante sed dapibus. Aenean sit amet aliquet dolor, at auctor erat.</p>
</div>
</div>
<h3 id="col-bleed">.col-bleed <a href="#col-bleed">&#35;</a></h3>
<p>Removes internal padding from a single <code>col-x</code> column element.</p>
<div class="grid">
<div class="col-6 col-bleed">
<p>.col-bleed</p>
</div>
<div class="col-6">
<p>Default column</p>
</div>
</div>
<h3 id="col-bleed-x">.col-bleed-x <a href="#col-bleed-x">&#35;</a></h3>
<p>Removes internal horizontal padding from a single <code>col-x</code> column element.</p>
<div class="grid">
<div class="col-6 col-bleed-x">
<p>.col-bleed-x</p>
</div>
<div class="col-6">
<p>Default column</p>
</div>
</div>
<h3 id="col-bleed-y">.col-bleed-y <a href="#col-bleed-y">&#35;</a></h3>
<p>Removes internal vertical padding from a single <code>col-x</code> column element.</p>
<div class="grid">
<div class="col-6 col-bleed-y">
<p>.col-bleed-y</p>
</div>
<div class="col-6">
<p>Default column</p>
</div>
</div>
</section>
<section class="container">
<h2 id="visibility-helpers">Visibility helpers <a href="#visibility-helpers">&#35;</a></h2>
<p>You can use some generic visibility helpers that can be applied to any element, not just grid elements. resize the viewport to see them in action. The breakpoints can be changed if you're building the css yourself by building the SCSS files.</p>
<div class="grid">
<div class="col-auto hidden-xxs">
<p>.hidden-xxs</p>
</div>
<div class="col-auto hidden-xs">
<p>.hidden-xs</p>
</div>
<div class="col-auto hidden-sm">
<p>.hidden-sm</p>
</div>
<div class="col-auto hidden-md">
<p>.hidden-md</p>
</div>
<div class="col-auto hidden-lg">
<p>.hidden-lg</p>
</div>
<div class="col-auto hidden-xlg">
<p>.hidden-xlg</p>
</div>
</div>
</section>
<section class="container">
<h2 id="flex-columns">Using flexbox in columns <a href="#flex-columns">&#35;</a></h2>
<p>By default, a <code>.col-x</code> element behaves like a good old fashioned block element but it is possible to modify it to perform as a flexbox element with <code>flex-direction: column</code> by adding the <code>.col-grid</code> class to any <code>col-x</code> element. This will allow you to take advantage of flexbox layout and (for example) create a footer that is always at the bottom of the column.</p>
<p>When a column has the <code>.col-grid</code> class applied to it, any of the grid modifiers such as <code>.justify-space-between</code> will work on it but be aware that the orientation is in the column direction and therefore the main axis is vertical.</p>
<p class="alert">When using flexbox for column layout, be aware that flex items cannot be floated and their margins do not collapse. Here's the relevant information from the flexbox spec:</p>
<blockquote>
A flex container establishes a new flex formatting context for its contents. This is the same as establishing a block formatting context, except that flex layout is used instead of block layout. For example, floats do not intrude into the flex container, and the flex containers margins do not collapse with the margins of its contents.
<footer><a href="https://www.w3.org/TR/css-flexbox-1/#flex-containers">flexbox spec</a>
</blockquote>
<p>As long as you're aware of these facts, you won't be surprised when you start using flexbox in columns.</p>
<h3 id="flex-footer">.flex-footer <a href="#flex-footer">&#35;</a></h2>
<p>A <code>.flex-footer</code> element that is the last child of a <code>.col-grid</code> column will always appear at the bottom of the column, regardless of how much content you have above it.</p>
<pre>&lt;div class="grid"&gt;
&lt;div class="col-6 col-grid"&gt;
&lt;content&gt;
&lt;div class="flex-footer"&gt;
&lt;p&gt;.flex-footer&lt;/p&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
<div class="grid">
<div class="col-6 col-grid">
<p>Aliquam ornare faucibus leo, vel euismod nisi porta non. Donec at arcu eget enim bibendum facilisis. Etiam urna elit, blandit ut libero placerat, iaculis aliquam erat.</p>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc et sagittis dui. Maecenas rhoncus justo aliquam urna finibus tincidunt et ut mauris.</p>
<div class="flex-footer">
<p>.flex-footer</p>
</div>
</div>
<div class="col-6 col-grid">
<p>Aliquam ornare faucibus leo.</p>
<div class="flex-footer">
<p>.flex-footer</p>
</div>
</div>
</div>
<h3 id="flex-img">.flex-img <a href="#flex-img">&#35;</a></h2>
<p>Responsive images are nothing new and most frameworks include classes to create them. For example, bootstrap uses <a href="https://getbootstrap.com/docs/4.0/content/images/#responsive-images">this solution</a>. However, there are some additional complexities in some browsers when using images as a flex item. Therefore, when using an image in a column with the <code>.col-grid</code> class, you should use the class <code>.flex-img</code> which solves these problems.</p>
<pre>&lt;div class="grid"&gt;
&lt;div class="col-6 col-grid"&gt;
&lt;img class="flex-img" src="images/1.jpg"&gt;
&lt;/div&gt;
&lt;/div&gt;</pre>
<div class="grid">
<div class="col-6 col-grid">
<img class="flex-img" src="images/1.jpg">
</div>
<div class="col-6 col-grid">
<img class="flex-img" src="images/2.jpg">
</div>
</div>
</section>
<section class="container">
<h2 id="cards">Cards <a href="#cards">&#35;</a></h2>
<p>A common use case for Reflex grid is to create product cards of the same height. The CSS for this is not part of Reflex grid and you would need to add your own card classes on top of reflex but I have included a few examples below and many more on the <a href="examples.html">examples page</a> to help you get started.</p>
<p>If you want to use these card styles as a starting point for your own implementation you can incorporate the <a href="https://github.com/leejordan/reflex/blob/master/docs/scss/includes/_cards.scss">SCSS I wrote for these cards</a> into your CSS build.</p>
<div class="grid grid-plain">
<div class="col-xs-6 col-md-3 col-grid">
<div class="card-body">
<h3>Amazing</h3>
<img class="flex-img" src="images/1.jpg">
</div>
<div class="card-body">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc et sagittis dui. Maecenas rhoncus justo aliquam urna finibus tincidunt et ut mauris.</p>
</div>
<div class="card-footer">
<span>$12.99</span>
<a href="#0">add to basket</a>
</div>
</div>
<div class="col-xs-6 col-md-3 col-grid">
<img class="card-header-img flex-img" src="images/2.jpg">
<div class="card-body">
<h3>Crazy good</h3>
<p>Nunc dignissim in ante sed dapibus. Aenean sit amet aliquet dolor, at auctor erat. Aliquam ornare faucibus leo, vel euismod nisi porta non.</p>
</div>
<div class="card-footer">
<span>$4.99</span>
<a href="#0">add to basket</a>
</div>
</div>
<div class="col-xs-6 col-md-3 col-grid">
<div class="card-body">
<h3>Lovely stuff</h3>
<p>Aenean sit amet aliquet dolor, at auctor erat. Aliquam ornare faucibus leo, vel euismod nisi porta non. Donec at arcu eget enim bibendum facilisis.</p>
</div>
<a href="#0" class="card-footer-link">read more</a>
</div>
<div class="col-xs-6 col-md-3 col-grid">
<a href="#0" class="card-link card-center">
<img class="card-img-circle flex-img" src="images/square-5.jpg">
<h3>Top destination</h3>
<p>Aenean sit amet aliquet dolor, at auctor erat. Aliquam ornare faucibus leo, vel euismod nisi porta non. Donec at arcu eget enim bibendum facilisis.</p>
</a>
</div>
</div>
</section>
<section class="container">
<h2 id="examples">Examples <a href="#examples">&#35;</a></h2>
<p>There are a handful of examples to show you what is possible with minimal effort on the <a href="examples.html">examples page</a></p>
</section>
<section class="container">
<h2 id="acknowledgements">Acknowledgements <a href="#acknowledgements">&#35;</a></h2>
<p><a href="https://www.browserstack.com"><img src="images/browserstack.png" alt="Browserstack logo"></a></p>
<p>I use <a href="https://www.browserstack.com">browserstack</a> to test this in different browsers and I'm a big fan of their service in general. Thanks Browserstack!</p>
<p>I would also like to acknowledge the following resources which all helped in some way while I was building this:</p>
<ul>
<li><a href="http://getbootstrap.com/" target="_blank">bootstrap</a> for some of the calculations and mixins</li>
<li><a href="https://css-tricks.com/snippets/css/a-guide-to-flexbox/" target="_blank">css-tricks</a> for their flexbox introduction</li>
<li><a href="https://philipwalton.com/articles/normalizing-cross-browser-flexbox-bugs/">Philip Walton</a> for his useful info about the ie10 flexbox implementation.</li>
<li><a href="http://caniuse.com/" target="_blank">caniuse</a> for browser coverage statistics</li>
<li><a href="http://lorempixel.com" target="_blank">lorempixel.com</a> for placeholder images</li>
<li><a href="https://icons8.com/">icons8</a> for the logo</li>
</ul>
</section>
</article>
</main>
<script src="js/contents.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js"></script>
<script>
WebFont.load({
google: {
families: ['Lora', 'Josefin Sans']
}
});
</script>
</body>
</html>