CSS HTML JS Minifier. Server Cache. CSS Properties are Alpha-Sorted, to help spot cloned. 'Apple Mac Os X Terminal by Loggerhead'). Respond to: HR Dept., Infinity Software, Inc., 659 Loggerhead Island Dr., Satellite Beach, FL 32937. Will also provide customized svc for client server applies.
Cascading style sheets can turn boring HTML documents into dynamic webpages, but haphazard use of CSS can cripple a website before it even starts rendering. This guide will cover some quick and easy ways to finetune your website’s CSS performance so that you can deliver content more quickly to your users.
What is CSS?
Cascading style sheets, or CSS, is the language used to define a website’s visual presentation based on the content provided in a markup language document. It is considered one of the “cornerstone technologies” of the web alongside HTML and JavaScript. CSS is typically stored in external stylesheets, or .css
files, but it can also be integrated directly into HTML documents.
CSS allows for a separation between a website’s presentation and content, which makes websites more accessible to different devices. Keeping information about colors and fonts separate from content also reduces website complexity since several HTML pages may share the same CSS file. However, if used improperly, CSS can become a stumbling block for your website’s performance from the outset.
CSS performance and website speed
When evaluating a website’s speed, there are a variety of performance metrics to measure, however two that stand out are:
- Time to first byte
- Time to start render
The time to first byte refers to how long it takes for visitors to receive the first byte of data after requesting your URL. The time to start render is the point at which the user’s browser actually begins displaying content. The former is largely dependant on your server setup, but the latter depends more on how your CSS is structured.
That said, browsers won’t start rendering until they receive data, so a slow time to first byte will obviously push back your time to start render. Therefore, you should prioritize resolving any potential issues with your server before you can reap the full benefits of optimizing your CSS performance.
How CSS performance affects time to start render
Before a browser can start laying out a webpage’s content, it needs instructions in the form of HTML and CSS. Thus, rendering cannot begin until all external stylesheets have been downloaded and processed. The more round trips this requires, the longer visitors have to wait.
Using external CSS involves making one or more HTTP requests, so your goal should be to minimize the number of required requests as much as possible. For example, putting your plugin, banner, and layout link styles into a single .css file can significantly speed up your time to first render. We have a tutorial on other ways to limit HTTP requests in WordPress websites.
Improving your CSS performance: An introduction to inlining
One way to ensure speedy delivery of CSS is the practice of inlining. Inlining means inserting external CSS resources directly into HTML documents. This technique works best for smaller resources, but it nonetheless makes a noticeable difference.
Inlining CSS cuts down on the amount of data the browser needs to download before it can start rendering a page. When you use external CSS files, they must be downloaded separately after your markup document finishes downloading. Inlining lets you kill two birds with one stone, so to speak.
To inline CSS, simply copy the desired CSS code from your external CSS file, and paste it between style tags in the head section of your HTML document like so:
Inlining larger CSS resources
If you try to inline a large CSS file, you may get a warning from your performance testing tool indicating that your above-the-fold content is too large. Therefore, for larger CSS files, you should inline only the CSS required to render your above-the-fold content. Then you should load the full stylesheet asynchronously so that the page can continue rendering while it’s being parsed.
Critical CSS is a GitHub project to help you pick out which CSS belongs above the fold, but you should also do a manual check to make sure no critical components were left out.
After minification and Gzip compression, all of your above-the-fold styles, scripts, markup should ideally weigh less than 14 kb in total. Since 14 kb is roughly the amount of data a server can send in the first round trip. Staying under that threshold allows users to get everything above the fold in the first data packet they receive.
Improving CSS performance with async loading and caching
The aforementioned trick saves the user’s browser one round trip to your server, so they’ll see content more promptly upon their first visit. Unfortunately, this perk comes with a price: The user’s browser doesn’t cache the CSS, so everything must be loaded from scratch upon each future visit. If you have fairly simple CSS, this isn’t such a problem; however, in most cases, you’ll still want the users’ browser to cache the majority of your CSS. That’s why many web developers just inline the CSS on their homepage or landing pages while using external CSS for the rest of their site.
A clever way to get around this issue involves asynchronous loading. Unfortunately, there isn’t a way to asynchronously load CSS files natively, but you can use a script like loadCSS.js to do the job.
Tools to improve CSS performance
If you want to see how other developers structure their CSS, Varvy’s CSS delivery tool can give you an overview of how any website uses CSS. It’s a great tool for evaluating your own projects and comparing them to others.
More tips for improving CSS performance
1. Use preload and HTTP/2 push
The preload resource hint tells browsers to fetch resources earlier than they would otherwise. To give your CSS a head start, set it as a link tag in your HTML document like this:
Alternatively, you can include preload as an HTTP header in your server configuration:
If your server is configured for HTTP/2 (which it should be) preload will be interpreted as a server push. KeyCDN also supports server push which will help even further accelerate the delivery oh high-priority CSS files. To learn more, read our HTTP/2 server push announcement blog.
2. Don’t inline everything
Don’t bother inlining everything within your HTML file as this will cause the initial HTML doc to increase in size and thus take longer for the TTFB.
3. Concatenate and minify your CSS
Concatenating your stylesheets into one file and sending out a minified version can drastically reduce the size of your CSS. Learn more about this process in our minify CSS, JS, and HTML article.
4. Reduce the size of your stylesheets
The smaller your stylesheets are, and the fewer selectors they contain, the less work browsers will have to perform when rendering your webpage. Therefore, you should do your best to remove unneeded selectors, leverage utility classes and avoid duplicate CSS code. You can use a tool such as uncss to make sure your stylesheet contains only the requisite CSS code.
5. Be selective of your selectors
Speaking of selectors, using the descendant selector forces browsers to check all of your descendant elements for a match, so they can create more problems than they revolve. Universal selectors can also be rather costly, so steer clear of them too. Use shallow selectors when possible.
6. Avoid expensive properties
Certain CSS properties are significantly more expensive than other ones, so they should be used conservatively. These are a few properties to watch out for:
- border-radius
- box-shadow
- filter
- :nth-child
- position: fixed;
- transform
It’s OK to use the above properties here and there, but if they appear hundreds of times per page, then your overall CSS performance may suffer.
7. Avoid @import
Never use the @import
directive to include external stylesheets because it blocks parallel downloads. This is an archaic practice. Instead, always use the link tag.
Summary
No matter how dazzling a webpage looks after it is finished loading, none of your efforts matter if visitors turn away before that point. Integrating the above strategies into your coding will allow you to build websites that render faster and perform more consistently, which will encourage new guests to keep coming back.
- Share
Website Layout
A website is often divided into headers, menus, content and a footer:
There are tons of different layout designs to choose from. However, the structure above, is one of the most common, and we will take a closer look at it in this tutorial.
Header
A header is usually located at the top of the website (or right below a top navigation menu). It often contains a logo or the website name:
Example
background-color: #F1F1F1;
text-align: center;
padding: 20px;
}
Result
Try it Yourself »Navigation Bar
A navigation bar contains a list of links to help visitors navigating through your website:
Example
.topnav {
overflow: hidden;
background-color: #333;
}
/* Navbar links */
.topnav a {
float: left;
display: block;
color: #f2f2f2;
text-align: center;
padding: 14px 16px;
text-decoration: none;
}
/* Links - change color on hover */
.topnav a:hover {
background-color: #ddd;
color: black;
}
Result
Try it Yourself »Content
The layout in this section, often depends on the target users. The most common layout is one (or combining them) of the following:
- 1-column (often used for mobile browsers)
- 2-column (often used for tablets and laptops)
- 3-column layout (only used for desktops)
We will create a 3-column layout, and change it to a 1-column layout on smaller screens:
Example
.column {
float: left;
width: 33.33%;
}
/* Clear floats after the columns */
.row:after {
content: ';
display: table;
clear: both;
}
/* Responsive layout - makes the three columns stack on top of each other instead of next to each other on smaller screens (600px wide or less) */
@media screen and (max-width: 600px) {
.column {
width: 100%;
}
}
Result
Column
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas sit amet pretium urna. Vivamus venenatis velit nec neque ultricies, eget elementum magna tristique.
Column
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas sit amet pretium urna. Vivamus venenatis velit nec neque ultricies, eget elementum magna tristique.
Column
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas sit amet pretium urna. Vivamus venenatis velit nec neque ultricies, eget elementum magna tristique.
Try it Yourself »Tip: To create a 2-column layout, change the width to 50%. To create a 4-column layout, use 25%, etc.
Tip: Do you wonder how the @media rule works? Read more about it in our CSS Media Queries chapter.
Tip: A more modern way of creating column layouts, is to use CSS Flexbox. However, it is not supported in Internet Explorer 10 and earlier versions. If you require IE6-10 support, use floats (as shown above).
To learn more about the Flexible Box Layout Module, read our CSS Flexbox chapter.
Unequal Columns
The main content is the biggest and the most important part of your site.
It is common with unequal column widths, so that most of the space is reserved for the main content. The side content (if any) is often used as an alternative navigation or to specify information relevant to the main content. Change the widths as you like, only remember that it should add up to 100% in total:
Example
float: left;
}
/* Left and right column */
.column.side {
width: 25%;
}
/* Middle column */
.column.middle {
width: 50%;
}
/* Responsive layout - makes the three columns stack on top of each other instead of next to each other */
@media screen and (max-width: 600px) {
.column.side, .column.middle {
width: 100%;
}
}
Result
Side
Lorem ipsum dolor sit amet, consectetur adipiscing elit..
Main Content
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas sit amet pretium urna. Vivamus venenatis velit nec neque ultricies, eget elementum magna tristique. Quisque vehicula, risus eget aliquam placerat, purus leo tincidunt eros, eget luctus quam orci in velit. Praesent scelerisque tortor sed accumsan convallis.
Side
Lorem ipsum dolor sit amet, consectetur adipiscing elit..
Try it Yourself »Footer
The footer is placed at the bottom of your page. It often contains information like copyright and contact info:
Example
background-color: #F1F1F1;
text-align: center;
padding: 10px;
}
Result
Try it Yourself »Responsive Website Layout
By using some of the CSS code above, we have created a responsive website layout, which varies between two columns and full-width columns depending on screen width: