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!
Editor’s note: This post formed the basis of the Front-End Optimization talk I’ve given in the past.
You’ve programmed websites for years, know the ins & outs of PHP, MySQL, why are Javascript and CSS files such a big deal? You put them in a directory, and link to them from your pages. Done. Right?
Not if you want maximum performance.
According to the Yahoo Exception Performance team:
…Only 10% of the time is spent here for the browser to request the HTML page, and for apache to stitch together the HTML and return the response back to the browser. The other 90% of the time is spent fetching other components in the page including images, scripts and stylesheets.
So static content is very important. The same Yahoo people provide us with a comprehensive list of Best (Front-end) Practices for Speeding Up Your Website. IMO, some of the rules are more important than others, and some are more easily achieved. Leaving aside hardware solutions (static server, CDN, etc.) for now, let’s look at six of the rules:
mod_deflate
in Apache. Rule 3 is a matter of configuring Apache. How to achieve the other five?
As I see it, there are three broad ways to achieve them.
<link rel="stylesheet" type="text/css" href="custom_handler.php?file1.css,file2.css" />
or something like that). It can also mean using mod_rewrite
to direct incoming requests for CSS and Javascript to go to a PHP script. Either way, there is processing on every page load. Caching the end-product helps. Still, there must be a better way. Don’t have a build server? That’s a whole other topic.