您好,登錄后才能下訂單哦!
本文實例講述了JavaScript函數定義方法。分享給大家供大家參考,具體如下:
JavaScript 函數定義方法
函數聲明
在之前的教程中,你已經了解了函數聲明的語法 :
function functionName(parameters) { 執行的代碼 }
函數聲明后不會立即執行,會在我們需要的時候調用到。
function myFunction(a, b) { return a * b; }
分號是用來分隔可執行JavaScript語句。
由于函數聲明不是一個可執行語句,所以不以分號結束。
函數表達式
JavaScript 函數可以通過一個表達式定義。
函數表達式可以存儲在變量中:
var x = function (a, b) {return a * b};
在函數表達式存儲在變量后,變量也可作為一個函數使用:
var x = function (a, b) {return a * b}; var z = x(4, 3);
以上函數實際上是一個 匿名函數 (函數沒有名稱)。
函數存儲在變量中,不需要函數名稱,通常通過變量名來調用。上述函數以分號結尾,因為它是一個執行語句。
盡量避免使用
new
關鍵字。
函數提升(Hoisting)
在之前的教程中我們已經了解了 "hoisting(提升)"。
提升(Hoisting)是 JavaScript 默認將當前作用域提升到前面去的的行為。
提升(Hoisting)應用在變量的聲明與函數的聲明。
因此,函數可以在聲明之前調用:
myFunction(5); function myFunction(y) { return y * y; }
使用表達式定義函數時無法提升。
自調用函數
函數表達式可以 "自調用"。
自調用表達式會自動調用。
如果表達式后面緊跟 () ,則會自動調用。
不能自調用聲明的函數。
通過添加括號,來說明它是一個函數表達式:
(function () { var x = "Hello!!"; // 我將調用自己 })();
以上函數實際上是一個 匿名自我調用的函數 (沒有函數名)。
函數可作為一個值使用
JavaScript 函數作為一個值使用:
function myFunction(a, b) { return a * b; } var x = myFunction(4, 3);
JavaScript 函數可作為表達式使用:
function myFunction(a, b) { return a * b; } var x = myFunction(4, 3) * 2;
函數是對象
在 JavaScript 中使用 typeof
操作符判斷函數類型將返回 "function" 。
但是JavaScript 函數描述為一個對象更加準確。
JavaScript 函數有 屬性 和 方法。
arguments.length
屬性返回函數調用過程接收到的參數個數:
function myFunction(a, b) { return arguments.length; }
toString()
方法將函數作為一個字符串返回:
function myFunction(a, b) { return a * b; } var txt = myFunction.toString();
更多關于JavaScript相關內容可查看本站專題:《JavaScript常用函數技巧匯總》、《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。