HASELT • Currently working with cutting edge front end technologies like: HTML5, CSS3, LESS, SASS, GulpJS, JavaScript, Polymer-Project, AngularJS, C# Razor, Web optimization, Web performance, Yeoman, Bootstrap, …. • Testing new unpublished and technologies in draft version and giving feedback to W3 group. Facebook: https://www.facebook.com/boban.radeski LinkedIn: mk.linkedin.com/pub/boban-radeski/38/952/a90/ Twitter: https://twitter.com/master_boban Boban Radeski Front end Development Engineer at HASELT
Use a Content Delivery Network • Caching • Gzip components • Put CSS at the top • Move scripts to the bottom • Make JavaScript and CSS external • Reduce DNS lookups • Minify JavaScript, CSS, HTML • Avoid redirects • Remove duplicate scripts • …… Boban Radeski Front end Development Engineer at HASELT
web sites. 80% of the end user response is spent on the front end. Most of time is tied up in downloading all the components in the page: images, stylesheets, scripts, etc. Reducing the number of components in turn reduces HTTP requests required to render the page. Boban Radeski Front end Development Engineer at HASELT
multiple, geographically dispersed servers will make your pages load faster from the user's perspective. A content delivery network (CDN) is a collection of web servers distributed across multiple locations to deliver content more efficiently to users. The server selected for delivering content to a specific user is typically based on a measure of network proximity. For example, the server with the fewest network hops or the server with the quickest response time is chosen. • There are a number of free CDNs offered by Google, Microsoft, Yahoo and other large web organizations. For example, few people host their own videos whenYouTube andVimeo offer amazing free services. Alternatively, you could use a private commercial CDNs such as Amazon S3, Microsoft Windows Azure andMaxCDN to host your own files. Boban Radeski Front end Development Engineer at HASELT
which means more scripts, stylesheets, images, and Flash in the page. A first-time visitor to your page may have to make several HTTP requests, but by using the Expires header you make those components cacheable. This avoids unnecessary HTTP requests on subsequent page views. The most often used with images, but they should be used on all components including scripts, stylesheets, and Flash components. • Browsers (and proxies) use a cache to reduce the number and size of HTTP requests, making web pages load faster. Boban Radeski Front end Development Engineer at HASELT
finding similar strings within a text file, and replacing those strings temporarily to make the overall file size smaller. This form of compression is particularly well-suited for the web because HTML and CSS files usually contain plenty of repeated strings, such as whitespace, tags, and style definitions. Boban Radeski Front end Development Engineer at HASELT Browser: Connects to server and requests page. Server that browser supports gzip "Accept-Encoding: gzip". Server: No gzip support. Ignores gzip request. Sends uncompressed page. Browser: Receive page. Display page. Browser: Connects to server. Notifies server that browser supports gzip "Accept-Encoding: gzip". Server: Acknowledges gzip support. Sends gzip encoded page with header "Content-Encoding: gzip". Browser: Receive page. Decode gzip encoded page based on header "Content-Encoding: gzip". Display page.
about performance want a page to load progressively; that is, we want the browser to display whatever content it has as soon as possible. This is especially important for pages with a lot of content and for users on slower Internet connections. Boban Radeski Front end Development Engineer at HASELT
scripts is that they block parallel downloads. The HTTP/1.1 specification suggests that browsers download no more than two components in parallel per hostname. If you serve your images from multiple hostnames, you can get more than two downloads to occur in parallel. While a script is downloading, however, the browser won't start any other downloads, even on different hostnames. Boban Radeski Front end Development Engineer at HASELT
the real world generally produces faster pages because the JavaScript and CSS files are cached by the browser. JavaScript and CSS that are inlined in HTML documents get downloaded every time the HTML document is requested. This reduces the number of HTTP requests that are needed, but increases the size of the HTML document. On the other hand, if the JavaScript and CSS are in external files cached by the browser, the size of the HTML document is reduced without increasing the number of HTTP requests. Boban Radeski Front end Development Engineer at HASELT
hostnames to IP addresses, just as phonebooks map people's names to their phone numbers. When you type www.yahoo.com into your browser, a DNS resolver contacted by the browser returns that server's IP address. DNS has a cost. It typically takes 20-120 milliseconds for DNS to lookup the IP address for a given hostname. The browser can't download anything from this hostname until the DNS lookup is completed. • DNS lookups are cached for better performance. This caching can occur on a special caching server, maintained by the user's ISP or local area network, but there is also caching that occurs on the individual user's computer. The DNS information remains in the operating system's DNS cache (the "DNS Client service" on Microsoft Windows). Most browsers have their own caches, separate from the operating system's cache. As long as the browser keeps a DNS record in its own cache, it doesn't bother the operating system with a request for the record. Reducing the number of unique hostnames has the potential to reduce the amount of parallel downloading that takes place in the page. Avoiding DNS lookups cuts response times, but reducing parallel downloads may increase response times. My guideline is to split these components across at least two but no more than four hostnames. This results in a good compromise between reducing DNS lookups and allowing a high degree of parallel downloads. Boban Radeski Front end Development Engineer at HASELT
302 status codes. Here's an example of the HTTP headers in a 301 response: • HTTP/1.1 301 Moved Permanently Location: http://example.com/newuri Content-Type: text/html • The browser automatically takes the user to the URL specified in the Location field. All the information necessary for a redirect is in the headers. The body of the response is typically empty. Despite their names, neither a 301 nor a 302 response is cached in practice unless additional headers, such as Expires orCache-Control, indicate it should be. The meta refresh tag and JavaScript are other ways to direct users to a different URL, but if you must do a redirect, the preferred technique is to use the standard 3xx HTTP status codes, primarily to ensure the back button works correctly. • One of the most wasteful redirects happens frequently and web developers are generally not aware of it. It occurs when a trailing slash (/) is missing from a URL that should otherwise have one. For example, going to http://astrology.yahoo.com/astrology results in a 301 response containing a redirect tohttp://astrology.yahoo.com/astrology/ (notice the added trailing slash). This is fixed in Apache by using Alias or mod_rewrite, or the DirectorySlashdirective if you're using Apache handlers. Boban Radeski Front end Development Engineer at HASELT
• Post and pre-load components • Reduce the Number of DOM Elements • Split Components Across Domains (static1.mywebpage.com and static2.mywebpage.com) • Don't Scale Images in HTML • Gulp, Grunt • ….. Boban Radeski Front end Development Engineer at HASELT
of images put into a single image. • A web page with many images can take a long time to load and generates multiple server requests. • Using image sprites will reduce the number of server requests and save bandwidth. Boban Radeski Front end Development Engineer at HASELT
http://filamentgroup.com/lab/performance-rwd.html?utm_source=CSS- Weekly&utm_campaign=Issue-122&utm_medium=web • http://www.sitepoint.com/web-site-optimization-steps/ Boban Radeski Front end Development Engineer at HASELT