Join the social network of Tech Nerds, increase skill rank, get work, manage projects...
 
  • How to eliminate render-blocking CSS?

    • 0
    • 0
    • 0
    • 0
    • 0
    • 0
    • 0
    • 0
    • 222
    Comment on it

    I was facing issue related with speed optimization of the web page. When there are many css on a single page, or have large size of css file then it makes your website slow. I am using Google PageSpeed insights to improve my site's performance. So the solution to this problem is to load the css when the content of the page has been loaded successfully. Suppose we have to load styles.css after the page is loaded, then we have to use the following script that will load just after the body has been loaded. Write this code in the footer.

     

    1. <script>
    2. /*!
    3. loadCSS: load a CSS file asynchronously.
    4. */
    5. function loadCSS(href){
    6. var ss = window.document.createElement('link'),
    7. ref = window.document.getElementsByTagName('head')[0];
    8.  
    9. ss.rel = 'stylesheet';
    10. ss.href = href;
    11.  
    12. // temporarily, set media to something non-matching to ensure it'll
    13. // fetch without blocking render
    14. ss.media = 'only x';
    15.  
    16. ref.parentNode.insertBefore(ss, ref);
    17.  
    18. setTimeout( function(){
    19. // set media back to `all` so that the stylesheet applies once it loads
    20. ss.media = 'all';
    21. },0);
    22. }
    23. loadCss('styles.css');
    24. </script>
    25. <noscript>
    26. <!-- Let's not assume anything -->
    27. <link rel="stylesheet" href="styles.css">
    28. </noscript>

    So all done, now you have successfully implemented render blocking css.

    Thanks for reading

 0 Comment(s)

Sign In
                           OR                           
                           OR                           
Register

Sign up using

                           OR                           
Forgot Password
Reset Password
Fill out the form below and reset your password: