首頁 >web前端 >js教程 >JavaScript自訂函數的寫法是什麼

JavaScript自訂函數的寫法是什麼

青灯夜游
青灯夜游原創
2021-07-06 15:11:035022瀏覽

js自訂函數的寫法:1、「function 函數名([args]){代碼}」;2、「var 函數名稱=new Function(p1, p2, ..., pn, body );」;3、「function ([args]){代碼}」。

JavaScript自訂函數的寫法是什麼

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

JavaScript中自訂函數的方法有 3 種,即使用 function 語句、使用 Function() 建構子和定義函數直接量。

宣告函數##​​

#在 JavaScript 中可以使用 function 語句宣告函數。具體用法如下:

function funName([args]) {
    statements
}

funName 是函數名,與變數名一樣必須是 JavaScript 合法的識別碼。在函數名稱之後是一個由一個小括號包含的參數列表,參數之間以逗號分隔。參數是可選的,沒有數量限制。

作為標識符,參數只在函數體內被訪問,參數是函數作用域的私有成員。呼叫函數時,透過為函數傳遞值,然後使用參數來取得外部傳入的值,並在函數體內幹預函數的運作。

在小括號之後是一個大括號,大括號內包含的語句就是函數體結構的主要內容。在函數體重,大括號是必不可少的,缺少大括號,JavaScript 將會拋出語法錯誤。

範例

function 語句必須包含函數名稱、小括號和大括號,其他程式碼都可省略,因此最簡單的函數體就是一個空函數。

function funName() {}  //空函数

如果使用匿名函數,則可以省略函數名稱。

function () {}  //匿名空函数

var 語句和 function 語句都是宣告語句,它們宣告的變數和函數都在 JavaScript 預先編譯時被解析,也稱為變數提升和函數提升。在預編譯期,JavaScript 引擎會為每個 function 建立上下文,定義變數對象,同時把函數內所有形參、私有變數、巢狀函數作為屬性註冊到變數物件上。


Function() 建構子

#使用 Function() 建構子可以快速產生函數。具體用法如下:

var funName = new Function(p1, p2, ..., pn, body);

Function() 的參數類型都是字串,p1~pn 表示所建立函數的參數名稱列表,body 表示所建立函數的函數結構體語句,在body 語句之間以分號分隔。

範例1

可以省略所有參數,只傳遞一個字串,用來表示函數體。

var f = new Function ("a", "b", "return a+b");  //通过构造函数来克隆函数结构

在上面程式碼中,f 就是所建立函數的名稱。同樣是定義函數,使用 function 語句可以設計相同結構的函數。

function f(a, b) {  //使用function语句定义函数结构
    return a + b;
}

範例2

使用 Function() 建構子可以不指定任何參數,建立一個空函數結構體。

var f = new Function();  //定义空函数

使用 Function() 建構子可以動態的建立函數,它不會把使用者限制在 function 語句預先宣告的函數體內。使用 Function() 建構函數能夠把函數當作表達式來使用,而不是當做一個結構,因此使用起來會比較靈活。其缺點就是,Function() 建構函式在執行期間被編譯,執行效率非常低,一般不建議使用。

匿名函數(函數直接量)

函數直接量也稱為匿名函數,即函數沒有函數名,只包含function 關鍵字、參數和函數體。具體用法如下:

function ([args]) {
    statements
}

範例1

下面程式碼定義一個函數直接量。

function (a, b) {  //函数直接量
    return a + b;
}

在上面程式碼中,函數直接量與使用 function 語句定義函數結構基本上相同,它們的結構都是固定的。但是函數直接量沒有指定函數名,而是直接利用關鍵字 function 來表示函數的結構,這種函數也稱為匿名函數。

範例2

匿名函數就是一個表達式,也就是函數表達式,而不是函數結構的語句。下面把匿名函數當作一個值賦值給變數 f。

//把函数作为一个值直接赋值给变量 f
var f = function (a, b) {
    return a + b;
};

當把函數結構當作一個值賦值給變數之後,變數就可以當作函數被調用,此時變數就指向那個匿名函數。

console.log(f(1,2));  //返回值3

範例3

匿名函數作為值,可以參與更複雜的表達式運算。針對上面範例可以使用以下程式碼完成函數定義和呼叫一體化操作。

console.log(  //把函数作为一个操作数进行调用
    (function (a,b) {
        return a + b;
    })(1, 2));  //返回数值3

【相關推薦:

javascript學習教學#

以上是JavaScript自訂函數的寫法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn