JavaScript学习笔记二——函数
来源:互联网 发布:b2b2c 商城app源码 编辑:程序博客网 时间:2024/05/16 09:56
在Javascript中,function才是Javascript的第一型。当我们写下一段函数时,其实不过是建立了一个function类型的实体。
就像我们可以写成这样的形式一样:
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引擎也就不会把他们放到一起了。
0 0
- JavaScript学习笔记二——函数
- JavaScript学习笔记(二) 对象与函数
- JavaScript——学习笔记(二)
- JavaScript基础学习笔记(二)——操作符、语句、函数
- JavaScript学习笔记——函数
- JavaScript学习笔记——函数
- JavaScript学习笔记(二)——客户端JavaScript
- Javascript学习笔记(二)Javascript核心之函数
- web学习—javascript学习—函数(二)
- JavaScript笔记——JavaScript的系统函数学习
- javascript 学习笔记二
- Javascript学习笔记二
- JavaScript学习笔记(二)
- Javascript 学习 笔记二
- javascript 学习笔记 (二)
- JavaScript学习笔记二
- javascript<二>---学习笔记
- JavaScript 学习笔记---------(二)
- JavaScript学习笔记一——数据类型
- PHP取得时间的年月日
- IOS TextView 自适应高度
- 如何让网站进入百度首页
- 海量数据面试题整理
- JavaScript学习笔记二——函数
- Java中基本类型Array与复合类型List的互相转换
- 多段线是否相交
- 综合图形学算法及OpenGL技术开发一个小型图形软件系统
- JavaScript学习笔记三——作用域
- 在Eclipse中使用JUnit4进行单元测试(高级篇)
- QML官方系列教程——Qt Quick Controls
- 概率论数理统计 挺全的
- Viewpager