Javascript学习笔记2 函数
2018-10-12 14:06
477 查看
就像我们可以写成这样的形式一样:
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。
这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:
我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:
这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。
function Hello() {
alert("Hello");
}
Hello();
var Hello = function () {
alert("Hello");
}
Hello();
其实都是一样的。
但是当我们对其中的函数进行修改时,会发现很奇怪的问题。
<script type="text/javascript">
function Hello() {
alert("Hello");
}
Hello();
function Hello() {
alert("Hello World");
}
Hello();
</script>
我们会看到这样的结果:连续输出了两次Hello World。而非我们想象中的Hello和Hello World。
这是因为Javascript并非完全的按顺序解释执行,而是在解释之前会对Javascript进行一次“预编译”,在预编译的过程中,会把定义式的函数优先执行,也会把所有var变量创建,默认值为undefined,以提高程序的执行效率。也就是说上面的一段代码其实被JS引擎预编译为这样的形式:
<script type="text/javascript">
var Hello = function() {
alert("Hello");
}
Hello = function() {
alert("Hello World");
}
Hello();
Hello();
</script>
我们可以通过上面的代码很清晰地看到,其实函数也是数据,也是变量,我们也可以对“函数“进行赋值(重赋值)。当然,我们为了防止这样的情况,也可以这样:
<script type="text/javascript">
function Hello() {
alert("Hello");
}
Hello();
</script>
<script type="text/javascript">
function Hello() {
alert("Hello World");
}
Hello();
</script>
这样,程序被分成了两段,JS引擎也就不会把他们放到一起了。
相关文章推荐
- JavaScript学习笔记-函数
- Javascript学习笔记(函数)
- javaScript学习笔记2---函数
- javaScript学习笔记——如何在加载完某个标签之后执行一个函数
- JavaScript 学习笔记之函数理解二
- JavaScript 学习笔记 五 函数作用域
- JS学习笔记1——不要使用JavaScript内置的parseInt()和Number()函数,利用map和reduce操作实现一个string2int()函数
- javascript学习笔记—判断值和函数的类型
- 韩顺平 javascript教学视频_学习笔记9_js函数调用过程内存分析_js函数细节
- javascript学习笔记四:javascript中的函数(对象)
- 《JavaScript高级程序设计 第三版》学习笔记 (六) 函数与闭包详解
- javascript学习笔记(3):函数与作用域
- javascript学习笔记---匿名函数,自执行函数
- [翻译]javascript学习笔记 (一)-函数基础
- 【JavaScript学习笔记】5:有关函数,typeof,参数过多/不足,arguments,rest
- JavaScript学习笔记之JS函数(一)
- javascript语言精粹学习笔记之函数的四种this调用模式
- JavaScript高程学习笔记之函数表达式(7)
- Javascript学习笔记3 函数表达式 闭包
- JavaScript 函数的call()方法的学习笔记