I want that my html page loads faster as it can. So I’m trying to put all CSS styles into the same .css file and all JavaScript code to the one .js file. How my colleagues told me it makes web page load faster. I want to ask some questions about it.
-
Just to be sure: Are my colleagues right? On which situations it’s better to break CSS or JS code to the separate files?
-
Question is: If I have a lot of small icons on my page, like “delete, edit, add”, should I load image with all icons at once or each icon separately? If I’ll load all icons at once, how do I select desired one, if icon’s size is 40x40px?
Thank you!
Single files can be downloaded with single HTTP requests (with single sets of HTTP headers, etc, etc) and can be compressed more efficiently then multiple files. So from a performance perspective, if you need all the content, it is better to place them in a single file.
When you need a specific page to load very quickly (e.g. the homepage) or when there are sections of the site which use a large chunk of script that isn’t used elsewhere then it can be beneficial to break the files up then.
From a performance standpoint, the same rules apply. However, there is no way to specify that a content image (and icons that don’t decorate text are content images) is just part of a larger file. You have to use hacks involving background images. This breaks the separation of concerns around content and style and usually involves using semantically incorrect elements, and then requires further hackery to provide alternative content for users who can’t see the image and that hackery rarely does as good a job as an alt attribute.
You have an element with specific dimensions and a background image with background-position set so that only the part of the image you want shows through.