Regular grid layout is based on both block and inline flow directions, however, the flexbox (or just flex) layout is based on "flex-flow
directions". Thus float
and clear
have no effect. Using float
actually causes the display
-property to compute back to block
. Using flexbox also means less JavaScript! And Flexgrid is, of course, responsive, mobile-first in mind, and stacks perfectly.
Flexgrid is open-source and everything can easily be modified. Let's say you want more or less than the standard 12 columns. Because Flexgrid is made with SCSS, you only have to edit a single digit, and then recompile. The entire sourcecode is available here on GitHub, where you're also welcome to fork the project.
Please note: Flexbox is only partially supported by IE 10. Any IE-version lower than 10 does not support flexbox. However, Flexgrid is powered by Autoprefixer that use Browserslist, which gets its data from Can I Use. By configuring autoprefixer, Flexgrid is supported all the way down to IE 10. Flexgrid also makes sure to support the latest Firefox ESR release.
You find everything fully documented at the new Docs page.
Use your favorite package manager to install Flexgrid
NPM:
$ npm install --save flexgrid.io
Yarn:
$ yarn add flexgrid.io
You can then easily import Flexgrid to your existing Sass/SCSS file:
@import 'flexgrid.io/src/flexgrid';
You can find Flexgrid on most public CDNs that cache npm packages, like unpkg, which will also pick up the correct version number if set up correctly:
<link rel="stylesheet" href="https://unpkg.com/flexgrid.io/dist/flexgrid.min.css">
If you need margin utilities included, you can add it the same way:
<link rel="stylesheet" href="https://unpkg.com/flexgrid.io/dist/flexgrid-utils.min.css">
If you for some reason want the latest old version, you can easily install it with NPM/Yarn as well:
$ npm install --save flexgrid.io@2.5.2 # yarn add flexgrid@2.5.2
A direct link for unpkg will need you to specify the version number like so: https://unpkg.com/flexgrid.io@2.5.2/dist/flexgrid.min.css
Flexgrid comes with 5 easy recognizable classes, if you're familiar with [Bootstrap]:
- xs (xtra small - for mobile devices and small tablets)
- sm (small - for large mobile devices and tablets)
- md (medium - for tablets and very small laptops)
- lg (large - for smaller laptops and -desktops)
- xl (xlarge - for desktops)
The classes can be combined to create more dynamic and flexible layouts.
Pro tip: Each class scales up, so if you wish to set the same widths for sm
and md
, you only need to specify sm
.
Flexgrid comes with responsive containers that boxes the content in which are controlled by @media
-queries. These @media
-queries trigger at the same widths defined by the Bootstrap-framework. However, as a small detail, Flexgrid bases its width-triggers on rem
instead of px
. This creates a much more fluid layout. While em
is relative to the font-size
of its direct or nearest parent, rem
is only relative to the html
(root) font-size
. Flexgrid font-size
is set to 16px
. There is also a fluid container that has no @media
-queries.
<!-- Container -->
<div class="container">
...
</div>
<!-- Container fluid -->
<div class="container-fluid">
...
</div>
The row is where it all happens. Whether you want to align your content, or you simply just want columns, the .row
-class is the one that sets display: flex
.
Flexgrid comes with columns with percent-based widths allow fluid resizing of columns and rows. Rows acts as alignment containers.
<div class="container">
<div class="row">
<div class="md-12">.md-12</div>
<div class="md-11">.md-11</div>
<div class="md-1">.md-1</div>
...
<div class="md-6">.md-6</div>
<div class="md-6">.md-6</div>
...
</div>
</div>
Flexgrid comes with a lot built-in methods to align your content the way you like it. It's never been easier to "center-center" your content. You can even offset columns or reorder them - and this follows the same pattern of being responsive and scalable.
It also comes with an optional utility toolbox where you can use margin as a way to offset/align your content. If you want these enabled, look below.
Flexgrid is not a framework, thus you won't find every single flexbox property in Flexgrid. As per the name, Flexgrid revolves around being a grid for building layouts.
However, Flexgrid *does* come with some of the most used properties, like alignment, offsets, margin utilities, etc. But to save space and to stick with the scope of the project, you won't find classes that sets display: flex
on elements, handles flex-direction
, flex-wrap
, and so on. I trust you to handle these yourself should you want to build more advanced layouts. However, there are mixins inside the source code for all of these, and thus very easy to build in the classes yourself.
A good example is the flexbox mixin found in /src/mixins/_flexgrid-mixins.scss
:
@mixin flexbox {
display: flex;
}
If you want expand Flexgrid and build a class into it that, in this case, sets display: flex
, it can easily be done by using the mixin:
.flex {
@include flexbox();
}
Just remember to @import
the mixins if you're not just editing the source (see below).
It's easy to modify the source. Clone this repository and edit away. Flexgrid comes with webpack that compiles the source for you with a single command.
If you want margin utilities enabled by default, just set the $enable-utils
-variable to true
and recompile. This variable can even be overwritten in your own SCSS-variables file if you're using Flexgrid as part of a project, as it's got the !default
-flag. Just remember to import Flexgrid before your own variables.
Compiling the source requires a terminal, and Node.js at least v12 (LTS), or Yarn.
To install the dependencies, you just run:
$ npm install # yarn install
When you're done editing, you just run:
$ npm run build # yarn run build
This will compile a regular .css
-file, and a minified .min.css
-file to the /dist
-folder.
3.0.4 (2019-12-19)
- Security updates
- Updated Netlify config
- Updated Travis CI config
- Updated CircleCI config
3.0.3 (2019-10-18)
- Updated webpack config
- Update of README with new documentation
- Removed
package-lock.json
from the project
3.0.2 (2019-10-17)
- Added compiled build including utilities. Find them at
/dist/flexgrid-utils.css
, etc. - Minor code clean-up
3.0.1 (2019-10-14)
- Renamed
_flexgrid
to_gridgenerator
after discovering some@import
issues in external projects because of name clashing - Updated dependencies
3.0.0 (2019-10-09)
- Complete transition to webpack
- Rewrite of the grid generator
- Simplified alignment class names
- Added optional margin utilities
- Added
space-evenly
(note: no support in IE,space-between
is used as fallback) - Ditched Tailwind syntax (use 2.x branch if you need it)
- Discarded demo files - use the new documentation website
Older changelogs can be found in the 2.x branch.
PR's are welcome encouraged.