javascript匿名函數(shù)實(shí)例分析
本文實(shí)例講述了javascript匿名函數(shù)的用法。分享給大家供大家參考。具體分析如下:
摘要:
本文講解的是javascript最基礎(chǔ)也是最重要的東西--函數(shù),之所以寫(xiě)這篇文章,是因?yàn)槊嬖嚨臅r(shí)候問(wèn)到了,也算是溫故而知新了。
先上個(gè)例子,如果你看懂了,說(shuō)明你已經(jīng)理解了本文要講的。
function f() {return 10;}
return f();
function f() {return 20;}
var f = 30;
})();
console.log(f);
javascript高級(jí)程序設(shè)計(jì)中這樣描述函數(shù)--可以封裝任意多條語(yǔ)句,而且可以在任何地方、任何時(shí)候調(diào)用執(zhí)行。之前介紹過(guò)了strict mode,嚴(yán)格模式對(duì)函數(shù)有一些限制:
① 不能把函數(shù)命名為eval或arguments
② 不能把參數(shù)命名為eval或arguments
③ 不能出現(xiàn)兩個(gè)命名參數(shù)同名的情況
發(fā)生以上情況就會(huì)導(dǎo)致語(yǔ)法錯(cuò)誤,代碼無(wú)法執(zhí)行。
函數(shù)定義
函數(shù)定義分為三種
1、構(gòu)造函數(shù)
2、普通定義
3、函數(shù)式定義
這三種方式都可以定義函數(shù)fun。
參數(shù)
函數(shù)不介意傳遞進(jìn)來(lái)多少個(gè)參數(shù),也不在乎傳進(jìn)來(lái)的參數(shù)是什么數(shù)據(jù)類型。即便你定義的函數(shù)只接收兩個(gè)參數(shù),在調(diào)用這個(gè)函數(shù)時(shí)也未必一定要傳遞兩個(gè)參數(shù)??梢詡鬟f一個(gè)、三個(gè)甚至不傳遞參數(shù)。原因是參數(shù)在內(nèi)部是用一個(gè)數(shù)組來(lái)表示的。在函數(shù)體內(nèi)可以通過(guò)arguments對(duì)象來(lái)訪問(wèn)參數(shù)數(shù)組,舉個(gè)例子
alert("Hello " + arguments[0] + "," + arguments[1]);
}
通過(guò)訪問(wèn)arguments對(duì)象的length屬性來(lái)獲知有多少個(gè)參數(shù)。函數(shù)的length會(huì)返回函數(shù)的參數(shù)個(gè)數(shù)。
注意:所有參數(shù)傳遞的都是值,不可能通過(guò)引用傳遞參數(shù)。
函數(shù)不能重載,只能重寫(xiě)
如果定義了兩個(gè)名字相同的函數(shù),則該名字只屬于最后定義的函數(shù),舉個(gè)例子:
function add(num) {
return num + 100;
}
function add(num) {
return num + 200;
}
var result = add(100) //300
注意:函數(shù)在執(zhí)行完return語(yǔ)句之后停止并立即退出。
函數(shù)種類
函數(shù)分為兩種一種是有名函數(shù),另一種是匿名函數(shù)。例如下面的有名函數(shù)
}
如果調(diào)用的話,只需要fun()就可以。
匿名函數(shù),顧名思義就是沒(méi)有函數(shù)名。例如
function() {}
函數(shù)調(diào)用是通過(guò)函數(shù)名來(lái)調(diào)用,匿名函數(shù)怎么調(diào)用呢?一種就是將匿名函數(shù)賦給一個(gè)變量,讓這個(gè)變量充當(dāng)函數(shù)名。另一種就是用()來(lái)調(diào)用,例如下面三種方法
1、(function() {return;}());
2、(function() {return;})();
3、function() {return;}();
例子:
(function(x, y) {
alert(x + y);
})(2,3);
//alert(5)
2和3將會(huì)作為參數(shù)傳遞給x和y
下面就來(lái)講講最上面的例子,這個(gè)例子里面涉及到閉包,后面會(huì)說(shuō)
首先定義一個(gè)變量f,然后賦值一個(gè)匿名函數(shù),這里呢需要注意一點(diǎn)函數(shù)里所有變量的定義都會(huì)被前置,所以匿名函數(shù)里的執(zhí)行順序是
var f = (function() {
var f = 30;
function f() {return 10;}
function f() {return 20;}
return f();
})();
外面的變量f和里面的變量f不在同一個(gè)作用域內(nèi)(閉包),所以互不影響。因?yàn)楹瘮?shù)不能重載,所以外面變量f=(function f() {return 20;})();,所以最終輸出的是20。
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
微信打開(kāi)網(wǎng)址添加在瀏覽器中打開(kāi)提示的辦法
這篇文章主要介紹了微信打開(kāi)網(wǎng)址添加在瀏覽器中打開(kāi)提示的辦法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05JS檢測(cè)頁(yè)面中哪個(gè)HTML標(biāo)簽觸發(fā)點(diǎn)擊事件的方法
這篇文章主要介紹了JS檢測(cè)頁(yè)面中哪個(gè)HTML標(biāo)簽觸發(fā)點(diǎn)擊事件的方法,涉及javascript頁(yè)面元素事件響應(yīng)機(jī)制,需要的朋友可以參考下2016-06-06JavaScript實(shí)現(xiàn)垂直滾動(dòng)條效果
這篇文章為大家詳細(xì)主要介紹了JavaScript實(shí)現(xiàn)垂直滾動(dòng)條效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01DOM節(jié)點(diǎn)深度克隆函數(shù)cloneNode()用法實(shí)例
這篇文章主要介紹了DOM節(jié)點(diǎn)深度克隆函數(shù)cloneNode()用法,實(shí)例分析了cloneNode()函數(shù)深度復(fù)制的操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01JavaScript本地儲(chǔ)存:localStorage、sessionStorage、cookie的使用
這篇文章主要介紹了JavaScript本地儲(chǔ)存:localStorage、sessionStorage、cookie的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10openLayer4實(shí)現(xiàn)動(dòng)態(tài)改變標(biāo)注圖標(biāo)
這篇文章主要為大家詳細(xì)介紹了openLayer4實(shí)現(xiàn)動(dòng)態(tài)改變標(biāo)注圖標(biāo),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08