函数的定义跟变量的定义过程差不多,那函数的定义就可以像变量一样进行。
var f = function fn(){
console.log(12)
}
这是定义一个变量,将函数代码放到变量空间中,这样的函数也是可以正常进行调用的,就使用变量的名称就行:
fn() //12
那fn这个函数的名字还能进行调用吗:
fn() // fn is not defined
这就说明,当将一个函数赋值给一个变量的时候,这个函数的名字就没有用了,所以我们可以将这个函数名称省略:
var f = function(){
console.log(12)
}
这样还是可以正常调用的:
f()
这种没有名字的函数就叫做匿名函数。
匿名函数不能单独存在,会报错:
function(){
console.log(13)
}
除非将这个函数用小括号括起来:
(function(){
console.log(13)
})
但是这种没有名字的函数就无法调用了,js提供了一个专门用来调用匿名函数的语法:
(function(){
console.log(13)
})()
后面加小括号就表示调用,这种定义并调用函数的语法,叫做自调用函数。即,函数定义好立即调用。自调用函数也可以不给函数加小括号,在函数前加感叹号或波浪线:
!function(){
console.log(14);
}()
~function(){
console.log(14);
}()
同样是立即执行的函数。这种函数也是可以传参数的:
(function(a,b){
var c = a + b;
document.write(c);
})(1,2);