Javascript学习笔记2——函数

在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引擎也就不会把他们放到一起了。

posted @ 2010-01-06 00:42 飞林沙 阅读(1089) 评论(9) 编辑 收藏

 回复 引用 查看   
#1楼 2010-01-19 20:16 唔愛吃蘋果      
忍不住说一句,写的太棒了。。。
 回复 引用 查看   
#2楼 2010-01-19 20:18 唔愛吃蘋果      
也会把所有var变量创建,默认值为undefined,以提高程序的执行效率

这句话没理解~~麻烦楼主解释解释!!!

 回复 引用 查看   
#3楼[楼主] 2010-01-19 20:48 飞林沙      
@唔愛吃蘋果

呵呵,你继续往下看:Javascript学习笔记3——作用域
如果你还是不明白的话,再问我

 回复 引用 查看   
#4楼 2010-01-23 23:09 show_show      
写得太好了 非常适合我们这样 对JS 半懂不懂 应用不行的人学习
 回复 引用 查看   
#5楼 2010-02-21 10:13 soldierluo      
楼主,第二段代码的结果出现的原因我觉得是因为在js被执行前会先扫描所有函数,而第二个hello函数因为和第一个函数hello同名,所以编译器将第一个函数覆盖了,所以在调用的时候只调用了了第二个hello函数
 回复 引用 查看   
#6楼[楼主] 2010-02-21 10:18 飞林沙      
@soldierluo

呵呵,根源在于"预编译"

 回复 引用 查看   
#7楼 2010-03-11 14:19 wslxlsjtc      
引用飞林沙:
@soldierluo

呵呵,根源在于"预编译"


 回复 引用 查看   
#8楼 2010-03-30 10:23 刘恩富      
分析的不错,很透彻。对学习JS和调试JS有很大帮助。
 回复 引用 查看   
#9楼 2011-07-07 18:07 壹伍叁柒      
受益匪浅
发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1640030 Y8ebZALVN9g=