Minimalistic flexbox CSS framework
CSS flexbox is already at around 98% browser support by usage. Thus, it is time to put an end to floats and inline-blocks and start creating beautiful responsive web sites using flexbox. If you prefer a minimalistic and non-opinionated CSS framework in the spirit of PURE CSS, you can give TAT a try. If you hate bloated frameworks like Bootstrap - you can give Tat a try.
This frameworks aims to:
- be very lightweight
- provide only the most common usages of flexbox and leave all the rest to your projects stylesheets
- deal only with layouts. No design-related stuff at all
- skip flexbox options that still have low support
TAT.CSS is now in version 1.0 and can be safely used in your projects.
There is only one file you need to include: tat.min.css Doing a CSS reset/normalise is up to you and is not included, but have in mind that you should probably set box-sizing to border-box to your grid elements. An optional normalise.css is included.
Naming logic
TAT aims to be very logical and simple in its class namings. Every class starts with "tat-", followed by row, alignment or element prefix, than by media query prefix and finally by sizing parameters.
Container types
There are 4 container types in TAT.CSS:
- single row (tat-r)
- single column (tat-c)
- multiple rows grid (tat-g)
- multiple columns (newspaper-style) grid (tat-n)
Every grid can be reversed in order by adding the "-r" parameter, i.e. "tat-c-r" is a reversed single column.
Grid alignments
The main axis alignment options are: tat-center, tat-left, tat-right, tat-hspace, tat-heven
The secondary axis alignments are: tat-top, tat-middle, tat-bottom, tat-vspace
Important: remember these actually deal with you main axis, but are named as if your main axis is horizontal. So if using a column (vertical) grid than "left" will mean "top" in absolute terms and so forth.
Element self-alignments
There are currently for options that have good browser support - top, bottom, center and stretch (remember, these are along the secondary axis, not the main one!). The prefix is "tat-s", i.e. "tat-s-top".
Media queries
TAT uses the same media queries as PURE CSS and follows the "mobile first" order.
- sm is above 35.5em
- md is above 48em
- lg is above 64em
- xl is above 80em
Example: class="tat-c tat-r-md" will produce a column order of elements in resolutions up to 48em and a row order above that.
Flex units
The "flex" unit in flexbox is very powerful and has plenty of use-cases in responsive web design. TAT only features a few predefined flex units from the endless possibilities – the ones that will probably be used most often in your project.
- tat-f-0-1 - element will not grow, but will shrink if needed
- tat-f-1-0 - element will grow to fill up space but will not shrink below its predefined width
- tat-f-0-0 - element is fixed size and will neither grow, nor shrink
- tat-f-1-1 - element will fully adapt its size to what is available
Flex units have no media queries in TAT. The idea behind flex units is to be natively adaptive, or in other words - to be flexible. If you want to change proportions use the standard fixed-width units.
Fixed units
The fixed units have a fixed width that is constant. You can use them in a tat-g grid, or you can combine them with flex rules in single rows/columns.
The units are proportion based and are named very similarly to PURE CSS, starting from tat-u-1 to tat-u-23-24. A major difference from Pure CSS is that in TAT there are no repeating proportions, so since there is tat-u-1-2 there is no tat-u-12-24.
The media query parameter goes after the "u" parameter: tat-u-sm-1-2, tat-u-lg-1-4, etc.
Other specifics
The beauty of flexbox is that every unit can also be a container, so this is quite possible: class="tat-u-1-2 tat-r". And it will clean up your html big time - no more nested divs with no content!
You can change the order of elements, not only by reversing the whole container, but individually. There are no classes in TAT.CSS for that at the moment - the usage is very site specific, so it doesn't make sense to include them here.
You probably start building a website from its header. Designing the header with CSS used to be a pain - the logo has to stay the same size, the slogan needs to adjust to available space and the menu changes its design completely from mobile to desktop. One would resort to a complicated combination of floats, absolute positioning, etc. Not anymore! With flexbox its so much easier. Here is the most basic example:
<header class="tat-c tat-r-md tat-middle">
<div id="logo" class="tat-f-0-0">Logo</div>
<div id="slogan" class="tat-f-1-1">Your company slogan!</div>
</header>
The logo div will remain the size of the image file (or the size set to #logo in your stylesheet), while the slogan div will fill in the remaining space and if the text is longer it will break into multiple text rows, while the two divs are always middle-aligned (center-aligned column on mobile). Nice, isn't it?