HTML5实战与剖析之延迟脚本
程序员文章站
2022-03-11 10:59:19
...
什么是延迟脚本呢?HTML5实战与剖析之延迟脚本是帮大家解决一些JavaScript加载问题的。有了HTML5实战与剖析之延迟脚本这个功能,我们可以不再为了JavaScript加载而发愁页面加载的时候结构会凌乱了。
说到JavaScript中的延迟脚本,早在HTML4.01的时候已经有了这样的属性。使用起来很方便,那就是在外部引用的script标签上加一个”defer”属性。加了”defer”属性,就不会影响页面的构造了。也就是说,脚本会加载但是不运行,等到页面全部加载完之后按顺序执行。为了能够更加理解,请看下面的例子。
在这个例子中,会有a.html文件,这个文件中引用的script标签没有添加延迟脚本的属性,而b.html文件添加了延迟脚本的属性。分别有两个JavaScript文件,分别是a.js和b.js,两个文件中各弹出自己文件的名字,以作示范。
a.js代码
alert("a");
b.js代码
alert("b");
a.html代码
<!doctype html> <html dir="ltr" lang="zh-CN"> <head> <meta charset="utf-8"> <title>梦龙</title> <script type="text/javascript" src="a.js"></script> <script type="text/javascript" src="b.js"></script> </head> <body> <p class="a"> 梦龙小站 </p> </body> </html>
b.html代码
<!doctype html> <html dir="ltr" lang="zh-CN"> <head> <meta charset="utf-8"> <title>梦龙</title> <script type="text/javascript" defer="defer" src="a.js"></script> <script type="text/javascript" defer="defer" src="b.js"></script> </head> <body> <p class="a"> 梦龙小站 </p> </body> </html>
上面的例子可以看出。虽然我们是在head标签中引用的a.js和b.js,但是由于我们设置了”defer”属性。所以引用的a.js和b.js会加载,只不过得在浏览器遇到标签之后再执行。由于浏览器解析延迟属性不一样,延迟脚本执行的顺序是不一样的。“defer”属性只适用于外部引用JavaScript文件,会忽略其他几种方法引用JavaScript文件的方法。
支持的浏览器有:IE9、Firefox 3.5、safari 5和chrome。其他不支持的浏览器会像正常一样加载和处理脚本。
以上就是HTML5实战与剖析之延迟脚本的内容,更多相关内容请关注PHP中文网(www.php.cn)!
推荐阅读
-
HTML5实战与剖析之字符集属性(charset和defaultCharset)
-
HTML5实战与剖析之使用HTML5 WebSocket API
-
HTML5实战与剖析之CSS选择器——querySelectorAll()
-
HTML5实战与剖析之CSS选择器——querySelector()
-
HTML5实战与剖析之触摸事件(touchstart、touchmove和touchend)
-
HTML5实战与剖析之原生拖拽(一拖拽历史概述)
-
HTML5实战与剖析之跨文档消息传递(iframe传递信息)
-
HTML5实战与剖析之表单那些事儿
-
HTML5实战与剖析之焦点管理(activeElement和hasFocus)
-
HTML5实战与剖析之媒体元素(2、媒体元素的属性)