I had an existing site I created using Blueprint CSS a while ago. I wanted to make it mobile-friendly. There are responsive CSS grid frameworks out there now, but I didn’t feel like replacing Blueprint, and I figured all I had to do was, using media queries, make every column span a fixed width. That was mostly correct. In the end, I used 100% widths, plus a few other alterations. Here is how I ended up doing it.
Normally, you will link to your Blueprint screen.css
file like so:
The following lines tell the browser to link first to a mobile-friendly CSS file. Then, if and when the width is 600px
, link to the normal, desktop CSS file. The idea is that bandwidth is scarcer on mobile, so we don’t mind downloading two files on a desktop machine if we have to.
To create my mobile.css
, I copied screen.css
, and made the following changes.
2px
th, td, caption {padding: 2px;}
a img {border:none;max-width:90%}
input
text fields to 67% width.
input.text, input.title {width: 67%; padding: 5px;}
textarea
inputs to 80% width, and reduce height
to 150px
.
textarea {width: 80%; height: 150px; padding: 5px;}
container
to 90% width.
.container {width: 90%; margin: 0 auto;}
span
grid classes to 100% width.
.span-1 {width: 100%;}
...
.span-24 {width: 100%; margin-right: 0;}
input.span
and textarea.span
classes, though I’m not sure why now.append
grid classes to 0px
right padding.
.append-1 {padding-right: 0;}
...
.append-24 {padding-right: 0;}
prepend
grid classes to 0px
left padding.
.prepend-1 {padding-left: 0;}
...
.prepend-24 {padding-left: 0;}
pull
grid classes to 0px
left margin.
.pull-1 {margin-left: 0;}
...
.pull-24 {margin-left: 0;}
push
grid classes to 0px
margin.
.push-1 {margin: 0;}
...
.push-24 {margin: 0;}
Not pretty, but it seems to work well. Happy CSS!
I am embarrassed to say that only somewhat recently did I figure out truly what a layout-based presentation (a.k.a. two-phase render) was all about. I’ve even used them before, and didn’t know why.
If you can’t tell someone clearly what is the benefit of two-phase render, go and read the Smarty documentation on it right now. Smarty calls it template inheritance, but IMO template inheritance, layouts, and two-phase render are all the same pattern.