- 相關(guān)推薦
javascript中的return和閉包函數
復制代碼 代碼如下:
function makefunc(x) {
return function (){
return x;
}
}
alert(makefunc(0));
其實(shí)不是不執行,只是朋友的意思這里alert出來(lái)的應該是“0”,而不是function (){return x;}。
不是腳本寫(xiě)錯了,只是沒(méi)搞懂return,從當前函數退出,并從那個(gè)函數返回一個(gè)值。如果返回的是一個(gè)函數,那么返回的也是函數本身。
可以這樣修改上面的代碼,就是alert(makefunc(0)()):
復制代碼 代碼如下:
function makefunc(x) {
return (function (){
return x;
})();
}
alert(makefunc(0)());
如果要返回函數執行的結果那么首先要讓這個(gè)函數執行,例如:
復制代碼 代碼如下:
function makefunc(x) {
return (function (){
return x;
})();
}
alert(makefunc(0));
這里有一個(gè)匿名函數,
復制代碼 代碼如下:
(function (){
return x;
})();
在第一個(gè)括號內是匿名函數,第二個(gè)括號用于調用該匿名函數,您可以在第二個(gè)括號中傳入所需的參數。例如:
復制代碼 代碼如下:
(function( x , y){
alert( x + y);
})(2 ,3 );
【javascript中的return和閉包函數】相關(guān)文章:
javascript的閉包概念怎么理解06-15
javascript閉包的定義及應用實(shí)例分析08-25
Javascript函數的定義和用法分析08-15
JavaScript中push(),join() 函數實(shí)例詳解09-05
最常用的20個(gè)javascript方法函數09-10