我们先直接看一个BUG
如果你知道这里为什么会报错,那就请跳过...
function fun(){
console.log("funciton1");
}
var a=fun;
a(); //function1
var del=function (a,b){
return a-b;
}
console.log(del(9,3));//6
var mul=function multiplay(a,b){
console.log(a*b);
console.log(multiplay);
}
mul(3,3)//9
console.log(multiplay(2,3))//error multiplay is not defined
js中两种最常用的创建函数对象的方法:函数声明和函数表达式。
函数声明
function bar() {
return 3;
console.log(bar);
}
函数声明可以定义命名的函数变量,而无需给变量赋值。
函数申明必须以function开头的函数。
函数名在自身的作用域和父级作用域是可以获取的。
函数声明必须要带一个标识符,也就是我们说的函数名。
函数表达式
//anonymous function expression
var a = function() {
return 3;
}
//named function expression
var a = function bar() {
return 3;
}
//self invoking function expression
(function sayHello() {
alert("hello!");
})();
将函数定义为表达式(通常为变量赋值)的一部分。
函数表达式可以是命名的也可以是匿名的。
函数表达式不能以function开头。
**函数名在作用域外是不可取的。**
回到之前的bug,我们来解释一下:
console.log(multiplay(2,3))//error multiplay is not defined
因为mul是以函数表达式的方式创建的函数对象,这个时候,函数名multiplay在作用域外是不可取的。