Javascript学习笔记2 函数_基础知识
程序员文章站
2022-05-19 21:29:13
...
就像我们可以写成这样的形式一样:
function Hello() {
alert("Hello");
}
Hello();
var Hello = function () {
alert("Hello");
}
Hello();
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。
这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:
我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:
这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。
复制代码 代码如下:
function Hello() {
alert("Hello");
}
Hello();
var Hello = function () {
alert("Hello");
}
Hello();
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
复制代码 代码如下:
我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。
这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:
复制代码 代码如下:
我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:
复制代码 代码如下:
这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。
推荐阅读
-
javascript 权威指南 学习笔记3:javascript 作用域
-
JavaScript闭包原理与用法学习笔记
-
javascript 权威指南 学习笔记2: Comparison Operators
-
javascript 权威指南 学习笔记1
-
JavaScript学习历程和心得小结_基础知识
-
JavaScript DOM 学习第七章 表单的扩展_基础知识
-
JavaScript高级程序设计(第3版)学习笔记 概述_基础知识
-
Ruffy javascript 学习笔记_基础知识
-
js下获得客户端操作系统的函数代码(1:vista,2:windows7,3:2000,4:xp,5:2003,6:2008)_javascript技巧
-
Python学习笔记(七)函数