之前对html中的js脚本的运行顺序一直没有认真的去理清思路,只是把几个用到的脚本文件随便放在头部,后面的文本中调用。
但是没有了解其运行顺序,在写代码是有时候会造成混乱。
今天抽了点时间测试了一下。
一、当有外联js时:
1、外联js出现在<head>标签中的时候,这时候的脚本是最早运行的,同时也是按照文档顺序自上而下运行的。
2、外联js出现在<body>标签中的时候,这时候脚本也是按照文档顺序运行的,与内嵌<body>的js脚本一样,执行到该语句就运行。
二、当<head>标签中有js脚本段落时,如果没有在$(function(){ }); 中的话:它会立即执行。如果是在$(function(){ }); 里面, 但它将在文档加载完毕后执行的。
三、<body>标签的js脚本段运行的顺序是: 当执行到该语句就运行。
四、可能的话,js脚本的具体执行语句一般放在<body>最后面中,这样可以确定js脚本是在所有页面元素加载完后才执行的。
PS: 对于一些公用函数的外联脚本,尽可能的放在<head>标签前部。 在一个js文件中,函数的调用可以不考虑它定义的顺序。但在多个js文件中,不同
文件中的函数的相互调用就要考虑这些函数的定义顺序了,不然会出现undefined错误。
2、可以概括的讲,在没有用 $(function(){}); 包住的js脚本将会按照document文档的顺序执行,并且对于其函数的调用没有顺序要求,只要定义了就可以调用。 而被$(function(){}); 包住的js脚本,则是在文档加载完毕后在按照document文档顺序执行,其优先级将会低于外部。
见例子:
<html> <head> <script type="text/javascript" src="js/jquery.js"></script> // 最先加载 <script type="text/javascript" src="js/first.js"></script> <script type="text/javascript" src="js/second.js"></script> <script type="text/javascript"> var app = {}; // 紧跟着外联js运行 $(function(){ // 将会在document文件加载完毕后运行,一般卸载这个js片段的尾部 function a1(){ } b(); // 调用文档底部的b()函数成功 }); var dpp = {}; // 紧跟app执行 a1(); // 调用失败,a1()函数 未定义 b(); // 调用失败,b() 函数为定义,因为不是出在同意js代码段,b()函数在这里还没有定义。 a2(); // 调用成功,同一个js代码段的函数无先后顺序 function a2(){ } </script> </head> <body> <script type="text/javascript" src="js/body.js"></script> // 程序执行到这里将会加载外联js <script type="text/javascript"> a1(); // 将会调用失败,函数未定义 a2(); // 能调用成功,函数已经在前面的js片段中定义了
b(); // 成功调用本js代码片段的函数
function b(){
}
$(function(){ // 这里面的代码将在前面的$(function(){}) 执行后在执行
// 代码
}) </script> </body> </html>