javascript代码执行顺序

javascript代码执行顺序

ID:15404899

大小:73.00 KB

页数:10页

时间:2018-08-03

javascript代码执行顺序_第1页
javascript代码执行顺序_第2页
javascript代码执行顺序_第3页
javascript代码执行顺序_第4页
javascript代码执行顺序_第5页
资源描述:

《javascript代码执行顺序》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、JavaScript执行顺序上一节是从JavaScript引擎的解析机制来探索JavaScript的工作原理,下面我们以更形象的示例来说明JavaScript代码在页面中的执行顺序。如果说,JavaScript引擎的工作机制比较深奥是因为它属于底层行为,那么JavaScript代码执行顺序就比较形象了,因为我们可以直观感觉到这种执行顺序,当然JavaScript代码的执行顺序是比较复杂的,所以在深入JavaScript语言之前也有必要对其进行剖析。1.1按HTML文档流顺序执行JavaScript代码首先,读者应该清楚,HTML文档在浏

2、览器中的解析过程是这样的:浏览器是按着文档流从上到下逐步解析页面结构和信息的。JavaScript代码作为嵌入的脚本应该也算做HTML文档的组成部分,所以JavaScript代码在装载时的执行顺序也是根据脚本标签如果通过脚本标签<

4、head>1.2预编译与执行顺序的关系在Javascript中,function才是Javascript的第一型。当我们写下一段函数时,其实不过是建立了一个function类型的实体。就像我们可以写成这样的形式一样:functionHello(){alert("Hello")

5、;}Hello();varHello=function(){alert("Hello");}Hello();其实都是一样的。但是当我们对其中的函数进行修改时,会发现很奇怪的问题。functionHello(){alert("Hello");}Hello();functionHello(){alert("HelloWorld");}Hello();我们会看到这样的结果:连续输出了两次HelloWorld。而非我们想象中的Hello和HelloWorld。这是因为

6、Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:varHello=function(){alert("Hello");}Hello=function(){alert("HelloWorld");}Hello();Hello();我们

7、可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:functionHello(){alert("Hello");}Hello();functionHello(){alert("HelloWorld");}Hello();这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。当JavaScr

8、ipt引擎解析脚本时,它会在预编译期对所有声明的变量和函数进行处理。做如下处理:1.在执行前会进行类似“预编译”的操作:首先会创建一个当前执行环境下的活动对象,并将那些用var申明的变量设置为活动对象的属性

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。