Deno 入門指南
Search…
⌃K

函式宣告

如果讀者有寫過程式,想必大家對於函式都不陌生。
除非你把邏輯都寫在 main() 啦,那就另當別論了 XDDD

什麼是函式?

函式 (function) 是執行特定工作的敘述集合,它的主要功能如下:
  • 將程式碼中的重複邏輯抽取出來,使程式碼更簡潔。
    原始程式碼:
    let a = 1 + 3;
    let b = a + 2;
    let c = a + b;
    let d = c + 1;
    使用函式後:
    sum(para1, para2){
    return para1 + para2;
    }
    let a = sum(1,3); // 1 + 3 = 4
    let b = sum(a,2); // 4 + 2 = 6
  • 當程式碼非常龐大時,可以依據不同的功能將程式碼分成好幾個片段,讓程式碼結構化以方便管理。

學習宣告函式!

在瞭解函式的定義以及用途以後,我們一起來學習如何宣告函式吧!
  • 原始作法
    我們將函式宣告以後沒有賦予它名字,便直接將其存放在 sum 變數中,這類函式又稱為匿名函式。
    let sum = function(para1, para2){
    return para1 + para2;
    }
    sum(1,2); //3
    當然,如果你希望它也有屬於自己的名字,也可以考慮這樣做:
    let sum = function myName(para1, para2){
    return para1 + para2;
    }
    注意 ! myName 這個名字只有在函式本身內有效,跳脫該函式的範圍後就沒有人認識他了 !
    let sum = function myName(para1, para2){
    console.log(myName); //valid
    return para1 + para2;
    }
    console.log(sum) //valid
    console.log(myName) //invalid
  • 簡潔作法
    function sum(para1, para2){
    return para1 + para2;
    }
    sum(1,2); //3
  • 使用 new Function 建構函式
    new Function (arg1, arg2, ... argN, functionBody)
    如果利用該方法去建構函式,先前的範例會變成:
    let sum = new Function ('para1', 'para2', 'return para1 + para2');
    筆者並不建議利用這個方式去宣告函式,因為該作法會讓編譯器需要花費多餘的性能去解析字串。
  • 物件函式縮寫
    一般情況,若我們需要在物件內宣告函式會需要這麼做:
    let obj = {
    sum: function(para1, para2){
    return para1 + para2;
    }
    };
    JavaScript ES2015 (ES6) 提供給我們更簡潔的作法:
    如果讀者對於 ES2015, ES2020... 等常見字眼感到疑惑,可以參考今天的延伸閱讀唷 !
    let obj = {
    sum(para1, para2){
    return para1 + para2;
    }
    };

補充: 立即函式 (IIFE)

懶人包: 定義完就執行的函式。
一般情況下,函式被定義後還需要被呼叫才會執行。不過,在 JavaScript 中有個特別的存在可以允許函式被定義後就立即執行。
下面範例為一般的函式,定義後需要呼叫才會將結果回傳。
function sum(para1, para2){
return para1 + para2;
}
let result = sum(1,2); //3
而 IIFE 比較特別,並不需要呼叫:
let result = function sum(para1, para2){
return para1 + para2;
}(1,2)
如果今天筆者不打算使用變數存放函式的結果,而是希望利用 IIFE 去做程式碼的初始化設定,可以這麼做:
(funtion init(){
console.log("Init!")
})()
或是利用 void 達到同樣的目的:
void funtion init(){
console.log("Init!")
}()
  • 知識點: void
    請參考延伸閱讀。
記住,當函式被宣告為立即函式後,便無法利用一般的方式呼叫它:
init()
錯誤代碼:
Uncaught ReferenceError: init is not defined

延伸閱讀

同樣的事情在不同人眼中可能會有不同的見解、看法。
在讀完本篇以後,筆者也強烈建議大家去看看以下文章,或許會對型別、變數宣告...等觀念有更深層的看法唷!
  • void
  • 六角學院共同創辦人 - 卡斯柏 大大的部落格也是學習前端技術的必讀網站,筆者學習相關知識時經常能夠在該網站獲得解答。因此,在這邊推薦給各位讀者。