函数也是对象,也是引用类型。
定义
两种定义方法都是等价的
function sum(arg1, arg2){
return arg1 + arg2;
}
var sum2 = function(arg1, arg2){
return arg1 + arg2;
}
函数指针
需要理解,函数名只是函数的指针,可以新建指针指向一个函数,也可以将原先指向函数的指针清空
function sum(arg1, arg2){
return arg1 + arg2;
}
var sum1 = sum; // 将sum1指向函数
alert(sum1(1, 2)); // 使用sum1
sum = null; // 清空原指针
alert(sum(1, 2)); // 报错,sum is not a function
没有重载
因为函数名字是指针,所以我们很好理解为什么js中没有重载的概念,因为指针不能指向两块内存。
那么想一想,如果函数定义两遍会怎么样?这事实上相当于后面的函数名覆盖了前面的函数名,只有后面的函数生效。
function ret(){
alert('1');
}
function ret(){
alert('2');
}
ret(); // 显示2,显示1的函数被覆盖
函数的参数
有意思的是,在调用函数的时候,可以传递比声明更多的参数,也可以不传参数。原因是不管传递多少参数,js都是用一个数组来接收参数的。如果传递了没有定义的参数,函数体内部用arguements也可以获取到参数。
arguement本身不是数组,它是一个对象,只是可以像数组那样去使用。
// 不定义参数名称
function SayHi(){
alert(arguments[0]);
}
SayHi("Hi");
arguement.length可以获得传入的参数数量
function SayHi(){
alert(arguments.length);
}
SayHi("Hi"); // 输出1
注意:在严格模式下,修改arguements的值和修改参数值不会互相影响,在非严格模式下,两者可以互相影响。
函数的返回值
在函数定义的时候,不需要指定是否有返回值
// 定义函数
function sayHi(name, message){
}
如果一个函数没有return任何值&