JavaScript——遞迴,嵌套和閉包
關於函數建立的三種方式以及遞迴,嵌套和閉包的概念經常容易搞混。
函數定義的三種方式:1.聲明式函數(標準的關鍵字function+函數名+(參數列表)+{函數主體})
例如:function functionname(param1,param2,......,paramn)
{function statment}
2.匿名式函數(將函數賦予的變數+建構函式Function+(參數))
例如:var variable=new Function(param1,param2,......,paramn,function body);
3.函數字面量:只會被瀏覽器解析一次(匿名和非匿名兩種)
A.匿名形式的(可以作為參數傳遞給另一個函數)
var func=function (param1,param2,......,paramn){function satament}
B.非匿名式的(適用函數內部,只有函數內部的代碼才能通過其名稱調用它,非常適合與遞迴)
var func=function functionname(param1,param2,......,paramn){function statment}
遞迴,嵌套和閉包的理解:
1.遞迴:一般是用來針對非匿名形式函數字面量和聲明式函數。
調用自身的函數稱為遞迴函式;
缺點:遞迴佔用的記憶體和資源比較多,同時難以實現和維護。
優點:在處理DOM之類的樹形結構資料時,非常適合用遞迴。
例如:function commonFunction()
{
var myFunc=function specialFunction(param1,param2,......,paramn)
{
function body;//存在某個判斷條件使遞迴最終跳出迴圈
return specialFunction(param1,param2,......,paramn);
}
var result=myFunc(param1,param2,......,paramn);
}
2.嵌套:不適用於匿名式函數(動態式),因為匿名式函數每次使用時都需要重構。
在某一函數內部存在了另一個函數就會形成嵌套。對於嵌套函數來言,內建函式在外部函數範圍內執行,並擁有對外部函數的參數和變數的訪問權。而外部函數沒有訪問內建函式的許可權。
內建函式通過外部函數傳遞給應用程式時將直接調用它,它可以使用作為參數傳遞給外部函數的參數值。
例如: <script>
function outerFunc(base)//外部函數
{
var outerStr=!!!!;
return function(ext){ //內建函式
return base+ext+outerStr;
}
}
function myApplication()//應用函數
{
var baseStr=outerFunc(Hello);//建立對內建函式的訪問
var newStr=baseStr(World);
alert(newStr);
}
</script>
3.閉包:可以在嵌套的基礎上理解閉包;當嵌套中的內建函式是以:A.內部對象形式建立的一個函數字面量B.並將其通過調用外部函數返回給主調應用程式中的一個變數,這就會形成一個JavaScript閉包。
應用:用來擷取內建函式中的變數值。因為外部函數a沒有訪問內建函式b中變數和參數的許可權,所以為了能夠使用內建函式b中的參數或變數,我們可以在內建函式b裡面建立一個對象形式的函數字面量c,這樣這個建立的函數字面量c就可以訪問內建函式b中的變數和參數。通過將內建函式b賦值給外部函數a中的變數,就可以通過外部函數a中的這個變數類比函數字面量c,實現對內建函式b的參數和變數的訪問。