函数——函数的两种声明方式:函数声明&函数表达式的区别(未完待续。。。)

Posted 雨落川下雪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数——函数的两种声明方式:函数声明&函数表达式的区别(未完待续。。。)相关的知识,希望对你有一定的参考价值。

一、函数声明中函数名是必须的;函数表达式中则是可选的

    //函数声明
    function sum(a, b) {
        return a + b;
    }
    alert(sum(1, 2));
    //函数表达式
    /* var s = function sum(a, b) {
        return a + b;
    }
    alert(s(1, 2)); */

    var s = function(a, b) {
        return a + b;
    }
    alert(s(1, 2));
    //以上两种都可以

二、用函数声明定义的函数,函数可以在函数声明之前调用,而用函数表达式定义的函数只能在声明之后调用。

【根本原因在于解析器对这两种定义方式读取的顺序不同:解析器会事先读取函数声明,即函数声明放在任意位置都可以被调用;

对于函数表达式,解析器只有在读到函数表达式所在那行的时候才执行】

    //函数声明
    alert(sum(1, 2));//3
    function sum(a, b) {
        return a + b;
    }
    //函数表达式:发生错误
    try {
        alert(s(1, 2));
        var s = function sum(a, b) {
            return a + b;
        }
    } catch (e) {
        alert("wrong!");
    }

补充说明:使用var 表达式定义函数, 只有变量声明提前了,变量初始化代码仍然在原来的位置

    /* try {
        alert(s);
    } catch (e) {
        alert("wrong!");//wrong!
    } */
    try {
        alert(s);//undefined
        var s = function sum(a, b) {
            return a + b;
        }
    } catch (e) {
        alert("wrong!");//未执行
    }
++腾讯面试实习生的问题【来源:http://www.2cto.com/kf/201409/331324.html
//下述两种声明方式有什么不同
function foo(){}; 
var bar = function foo(){};

以上是关于函数——函数的两种声明方式:函数声明&函数表达式的区别(未完待续。。。)的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript函数的两种声明方式

JavaScript函数的两种声明方式

JS定义函数的两种方式:函数声明和函数表达式

函数声明的两种形式的区别

javascript函数篇函数声明提升

在堆栈上声明对象的两种方式之间的区别