首頁  >  文章  >  web前端  >  javascript定義函數的幾個類型是什麼

javascript定義函數的幾個類型是什麼

WBOY
WBOY原創
2022-03-10 14:57:062468瀏覽

在JavaScript中定義函數的幾種類型:1、利用function關鍵字透過宣告或表達式定義函數,語法為「function functionName(parameters){執行的程式碼}」;2、利用函數構造器Function()建構函數。

javascript定義函數的幾個類型是什麼

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

javascript定義函數的幾種類型是什麼

JavaScript 使用關鍵字 function 定義函數。

函數可以透過宣告定義,也可以是一個表達式。

函數宣告

在先前的教學中,你已經了解了函數宣告的語法 :

function functionName(parameters) {
  执行的代码
}

函數宣告後不會立即執行,會在我們需要的時候調用到。

函數建構器

函數建構器用來建立一個函數對象,在JavaScript中實際上每個函數都是一個函數對象。

函數建構器的語法:

new Function ([arg1[, arg2[, ...argN]],] functionBody)

arg1, arg2, ... argN  被用來作為函數正常參數名的變數名字,這些變數名稱必須是符合JavaScript變數識別規格的表示單一變數的字串或以逗號分隔的表示多個變數的字串,例如"x", "theValue", or "a,b"。

functionBody   包含函數定義的JavaScript語句的字串。

描述

1.函數物件在函數建構器被解析成為函數的時候被創建。但這樣會比以函數宣告、函數表達式等方式低效,因為這些函數時會透過程式碼直接解析的。

2.傳遞給函數建構器的字串參數都會被當作函數建構器產生函數的變數參數名字,以他們出現的順序作為產生的函數的參數的順序。

3.以函數的方式呼叫函數建構器(不管用不用new關鍵字修飾)效果一樣。

範例

// Example can be run directly in your JavaScript console
// Create a function that takes two arguments and returns the sum of those arguments
var adder = new Function('a', 'b', 'return a + b');
// Call the function
adder(2, 6);
// > 8

 參數a和b是可以在函數體內使用的正常的參數名字。

產生的函數為:

function (a,b){undefined
  return a+b;
}

關於json解析的一種方式:var json = (new Function("return "   str))();

#原則一樣,

產生的函數為:

function toJson(str){undefined
   return str;
}
var str="{'a':1,'b':'abc'}";
toJson(str);

即:function(){return {'a':1,'b':'abc'}}

#函數構造器和函數宣告的差異:

用函數建構器建立的函數不會在上下文中建立閉包,它們總是被創建在全域作用域中,當執行被建立的函數時,它們只能使用自己的局部變數或全域變量,這和eval是不同的。

相關推薦:javascript學習教學

以上是javascript定義函數的幾個類型是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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