Skip to content

boyanraichev/tat-css

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

tat-css

Minimalistic flexbox CSS framework

Objectives

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.

Get Started

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.

Examples

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?

About

Minimalistic flexbox CSS framework

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages