5.5 Function類型

好記性不如爛筆頭

函數實際上是對象,每個函數都是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
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容