好記性不如爛筆頭
函數實際上是對象,每個函數都是Function類型的實例。與其他引用類型都一樣具有屬性和方法。由于函數是對象,所以每一個函數名都是指向函數對象的指針,不會與某個函數對象綁定。
1.函數的定義方法
- 使用函數聲明語法:
function sum(num1,num2){
return num1+num2;
}```
- 使用函數表達式
var sum=function(num1,xum2){
return num1+num2;
};//結尾要有分號,就像聲明其他變量一樣```
- 使用Function構造函數
var sum=Function("num1","num2","return num1+num2");//不推薦
由于函數名是指針,所以和其他包含對象指針的變量沒有什么區別。也就是說一個函數可以有多個名字,例如:
function sum(num1,num2){
return num1+num2;
}
alert(sum(10,10));//20
var xiaoxiao=sum;
alert(xiaoxiao(10,10));//20
sum=null;
alert(xiaoxiao(10,10));//20
2.ECMAscript沒有重載
3.函數聲明和函數表達式的區別
alert(sum(10,10));//20
function sum(num1,num2){
return num1+num2;
}
以上的代碼可以正常運行,但下面的會產生錯誤
alert(sum(10,10));
var sum=function(num1,num2){
return num1+num2;
}
原因是在代碼開始執行的時候,js解析器通過一個叫做“函數聲明提升”的過程將函數聲明添加到了執行環境中。
除此之外,他們沒有什么區別。甚至可以一起用,例如:
var sum=function sum(){}
但遺憾的是,在safari中會產生錯誤。
4.作為值存在的函數
因為ECMAscript中的函數名本身就是變量,所以函數也可以作為值來使用。函數可以作為參數來傳遞給另外一個函數,也可以作為值返回。看下面的例子:
function callSomeFunction(someFunction,someArguement){
return someFunction(someArgue);
}
function add10(num){
return num+10;
}
var result1=callSomeFunction(add10,10);
alert(result1);//20