javascript的执行顺序
javascript执行顺序
之前从javascript引擎的解析机制来探索javascript的工作原理,下面我们以更形象的示例来说明javascript代码在页面中的执行顺序。如果说,javascript引擎的工作机制比较深奥是因为它属于底层行为,那么javascript代码执行顺序就比较形象了,因为我们可以直观感觉到这种执行顺序,当然javascript代码的执行顺序是比较复杂的,所以在深入javascript语言之前也有必要对其进行剖析。
1.1 按html文档流顺序执行javascript代码
首先,读者应该清楚,html文档在浏览器中的解析过程是这样的:浏览器是按着文档流从上到下逐步解析页面结构和信息的。javascript代码作为嵌入的脚本应该也算做html文档的组成部分,所以javascript代码在装载时的执行顺序也是根据脚本标签<script>的出现顺序来确定的。例如,浏览下面文档页面,你会看到代码是从上到下逐步被解析的。
<script>
alert("顶部脚本");
</script>
<html><head>
<script>
alert("头部脚本");
</script>
<title></title>
</head>
<body>
<script>
alert("页面脚本");
</script>
</body></html>
<script>
alert("底部脚本");
</script>
如果通过脚本标签<script>的src属性导入外部javascript文件脚本,那么它也将按照其语句出现的顺序来执行,而且执行过程是文档装载的一部分。不会因为是外部javascript文件而延期执行。Pc.zx98.com例如,把上面文档中的头部和主体区域的脚本移到外部javascript文件中,然后通过src属性导入。继续预览页面文档,你会看到相同的执行顺序。
<script>
alert("顶部脚本");
</script>
<html>
<head>
<script src="head.js"></script>
<title></title>
</head>
<body>
<script src="body.js"></script>
</body>
</html>
<script>
alert("底部脚本");
</script>
1.2 预编译与执行顺序的关系
在javascript中,function才是javascript的第一型。当我们写下一段函数时,其实不过是建立了一个function类型的实体。
就像我们可以写成这样的形式一样:
functionhello() {
alert("hello");
}
hello();
varhello = function() {
alert("hello");
}
hello();
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
<scripttype="text/javascript">
functionhello() {
alert("hello");
}
hello();
functionhello() {
alert("hello world");
}
hello();
</script>
我们会看到这样的结果:连续输出了两次hello world。而非我们想象中的hello和hello world。
这是因为javascript并非完全的按顺序解释执行,而是在解释之前会对javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有va [1] [2] [3] [4] [5] 下一页
|