About async and defer of external javascripts. What if we use them both (whether it’s worth)? And how they’re actually loading in what order | |
Author: utilmind |
Questions:
Answers: Both “async” and “defer” loading external script asynchronously. So you don't need to set both atributes, unless you really need exactly "async", but still want to make it compatible with legacy browsers. In modern browsers, if you use both async+defer, “async” has higher priority and “defer” is ignored. You should prefer “async” if you want to interact your script with page immediately after script will be loaded, no matter before or after the page will be loaded. Use “defer” for the scripts which depends on each other, which should be loaded and executed in some certain strict order. For example, if you use jQuery and some jQuery plugins, you should put jQuery to the top of your scripts list with “defer” attribute + all other scripts which requires jQuery — after the jQuery, with “defer” attributes too. But never set “async” to the scripts, if you're using some other other external scripts which depends on it. Because of “async” directive it will be executed in any unpredictable place/time once it will be loaded + “defer” will be ignored. And again, both “async” and “defer” loading external script asynchronously, without blocking of the page content. BTW.
|
Tweet |
Send by E-mail Print version |