If you were not aware of them CSS Regions are proposal to CSS3 that would allow for some magazine like layouts in HTML pages. Adobe has been leading the charge on getting them into WebKit. They are currently available in Chrome. (Also I think IE10)
Now the way they work:
- You create a bit of content in an element like an article
- You designate that article as the source of a “flow”
- You designate other elements as the recipients of the “flow” (We’ll call them “regions”)
Then when the browser renders the content
- The element designated as the “flow” is not shown
- The content of the “flow” pours into the “regions”
Assuming this HTML:
And this CSS:
You get something like this:
I have a demo. It only works in Chrome. Resize the screen to see the flowing of the content.
I was presenting on them the other night and I got asked a pretty good question.
Have you thought about how these degrade?
I made a bad joke, then mumbled something about if the browser doesn’t support CSS Regions then the original “flow” element gets displayed and all is well.
I tested it today. And all is not well. Because I still created those region elements. And they show up down at the bottom and add whitespace.
Check out the demo on any browser bu Chrome and you’ll see what I’m talking about all the way at the bottom.
So after some experimentation I decided that the best way to handle this was to create my four regions with CSS exactly how I had but only inject the region holders if the browser supports regions, like so:
In this case, I get a much better experience for non Chrome users–no weird mile of whitespace at the bottom of the content.