博客
关于我
JS代码执行顺序
阅读量:702 次
发布时间:2019-03-21

本文共 785 字,大约阅读时间需要 2 分钟。

JavaScript是以段落为单位分析和执行程序的,而不是严格的一行一行执行。特别是当分析同一段代码时,定义式的函数语句会被提取出来优先执行,完成之后才会继续执行其他代码。这种特性决定了代码的执行顺序和结果。

举个例子来说明:

假设我们在同一段代码中定义了两个函数:

const hello = function(){alert('hello,zhangsan');};hello(); //第一次调用,输出"hello,zhangsan"

var hello = function(){alert('hello,lisi');};hello(); //第二次调用,输出"hello,lisi"

这里的结果是每次调用都会输出"hello,lisi",这是怎么回事呢?因为我们在第一次调用之前就已经定义了第二个函数。

另一个例子来说明:

function hello(){alert('hello,zhangsan');}

hello(); //第一次调用,输出"hello,zhangsan"

function hello(){alert('hello,lisi');}

hello(); //第二次调用,输出"hello,lisi"

你发现调用的结果是一样的,也是"hello,lisi"。这是因为在第一次调用函数之前,第二个函数已经被定义并占用了名称空间。函数定义会影响最终的执行结果。

关于变量初始化的问题:

变量t = 1;

function con(){
console.log(t);
t = 2;
console.log(t);
}
con();

输出结果会是undefined和2。这是因为在函数执行过程中,变量t的初始值是undefined,只有在变量被重复赋值t = 2之后,t才被赋值为2。因此,无论函数在哪个阶段调用,它都会根据当前的变量值输出。

转载地址:http://hndrz.baihongyu.com/

你可能感兴趣的文章
windows环境下安装zookeeper(仅本地使用)
查看>>
缓冲区溢出实例(一)--Windows
查看>>
Hadoop学习笔记—Yarn
查看>>
Jenkins - 部署在Tomcat容器里的Jenkins,提示“反向代理设置有误”
查看>>
wxWidgets源码分析(3) - 消息映射表
查看>>
wxWidgets源码分析(5) - 窗口管理
查看>>
wxWidgets源码分析(8) - MVC架构
查看>>
wxWidgets源码分析(9) - wxString
查看>>
[梁山好汉说IT] 梁山好汉和抢劫银行
查看>>
[源码解析] 消息队列 Kombu 之 基本架构
查看>>
[源码分析] 消息队列 Kombu 之 启动过程
查看>>
wx.NET CLI wrapper for wxWidgets
查看>>
Silverlight for linux 和 DLR(Dynamic Language Runtime)
查看>>
ASP.NET MVC Action Filters
查看>>
Powershell中禁止执行脚本解决办法
查看>>
OO_Unit2 多线程电梯总结
查看>>
git clone 出现fatal: unable to access ‘https://github 错误解决方法
查看>>
04_Mysql配置文件(重要参数)
查看>>
python 加密算法及其相关模块的学习(hashlib,RSA,random,string,math)
查看>>
JavaSE总结
查看>>