zoukankan      html  css  js  c++  java
  • javascript 函数声明和函数表达式的区别(学习笔记)

    javascript中声明函数的方法有两种:函数声明式和函数表达式.

    区别如下:

    1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的.

    2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,而函数表达式的函数只能在声明之后调用.

    3).以函数声明的方法定义的函数并不是真正的声明,它们仅仅可以出现在全局中,或者嵌套在其他的函数中,但是它们不能出现在循环,条件或者try/catch/finally中,而

        函数表达式可以在任何地方声明.

    下面分别用两种方法定义函数:

     1 //函数声明式
     2 function greeting(){
     3       console.log("hello world");  
     4 }
     5 
     6 
     7 //函数表达式
     8 var greeting = function(){
     9     console.log("hello world"); 
    10 }

    下面一个有趣的javascript:

    1 function f() { console.log('I am outside!'); }
    2 (function () {
    3   if(false) {
    4     // 重复声明一次函数f
    5     function f() { console.log('I am inside!'); }
    6   }
    7   f();
    8 }());

    会输出什么呢?第一反应应该是"I am outside"吧.  结果在chrome中输出"I am inside",IE11直接报错,firefox低一点的版本输出"I am outside"...

    chrome输出的结果很明确的反应了用函数声明式声明的函数的特点--函数在声明之前就可以调用.

    IE报错显示缺少对象,因为函数声明在了条件里,违背了函数声明式的原则.

    函数表达式的作用域:

    如果函数表达式声明的函数有函数名,那么这个函数名就相当于这个函数的一个局部变量,只能在函数内部调用,举个栗子:

    1 var f = function fact(x) { 
    2                 if (x <= 1) 
    3                     return 1;
    4                 else 
    5                     return x*fact(x-1);
    6                 };
    7                 alert(fact());   // Uncaught ReferenceError: fact is not defined
    fact()在函数内部可以调用,在函数外部调用就会报错:fact未定义.
    fact
  • 相关阅读:
    ASP.NET MVC @helper使用说明
    asp.net批量发布博客到各大博客平台
    大型网站架构学习
    Js获取日期时间及其它操作
    Asp.net 后台添加Meta标签方法
    正则表达式排除特定字符串
    asp.net正则表达式过滤标签和数据提取
    <pages validateRequest="false"/>在.net4.0中无效的问题
    IE6、IE7、IE8中overflow:hidden无效问题
    如何在 Django 中保证并发的数据一致性
  • 原文地址:https://www.cnblogs.com/huangxi/p/4179154.html
Copyright © 2011-2022 走看看