Javascript 高階函數(shù)使用介紹
高階函數(shù)(higher-order function)—如果一個(gè)函數(shù)接收的參數(shù)為或返回的值為函數(shù),那么我們可以將這個(gè)函數(shù)稱為高階函數(shù)。眾所周知,JavaScript是一種弱類型的語言:JavaScript的函數(shù)既不對(duì)輸入的參數(shù),也不對(duì)函數(shù)的輸出值作強(qiáng)定義和類型檢查,那么函數(shù)可以成為參數(shù),也可以成為輸出值,這就體現(xiàn)了JavaScript對(duì)高階函數(shù)的原生支持。
一、參數(shù)為函數(shù)的高階函數(shù):
function funcTest(f){ //簡(jiǎn)易判斷一下實(shí)參是否為函數(shù) if((typeof f)==”function”){ f(); }} funcTest(function(){ });
這是一個(gè)簡(jiǎn)易的將參數(shù)作為函數(shù)的高階函數(shù)。在調(diào)用funcTest時(shí),輸入一個(gè)函數(shù)作為參數(shù),在funcTest內(nèi)部執(zhí)行這個(gè)輸入的匿名函數(shù),當(dāng)然這樣的代碼片段沒有什么實(shí)際意義。
一、返回值為函數(shù)的高階函數(shù):
function funcTest(){ return function(){}; } var f=funcTest();
調(diào)用funcTest返回一個(gè)函數(shù)。
二、一個(gè)復(fù)雜一點(diǎn)的例子:
//Number類型相加 function addInt(a,b){ return parseInt(a)+parseInt(b); } //String類型相加 function addString(a,b){ return a.toString()+ b.toString(); } function add(type){ if(type==="string"){ return addString; }else{ return addInt; } } var data1=add("string")("1","2"); //12 var data2=add("int")("1","2"); //3
以上示例實(shí)現(xiàn)了一個(gè)String類型相加與Number類型相加的分離。調(diào)用add函數(shù)如果輸入?yún)?shù)為”string”時(shí),輸出一個(gè)字符串拼接函數(shù);如果輸入?yún)?shù)為”int”則輸出數(shù)字相加函數(shù)。
三、高階函數(shù)的實(shí)際作用:
上面的代碼示例基本說明什么是高階函數(shù),下面來看看高階函數(shù)與我們實(shí)際編程有什么關(guān)系:
1,回調(diào)函數(shù)
function callback(value){ alert(value); } function funcTest(value,f) //f實(shí)參檢測(cè),檢查f是否為函數(shù) if(typeof callback==='function'){ f(value);}}funcTest(‘1',callback); //1
示例在當(dāng)調(diào)用funcTest時(shí),funcTest內(nèi)部會(huì)調(diào)用callback函數(shù),即實(shí)現(xiàn)回調(diào)。
2,數(shù)據(jù)篩選與排序算法
var arr=[0,2,11,9,7,5]; //排序算法 function funcComp(a,b){ if(a<b){ return -1; }else if(a>b){ return 1; }else{ return 0; } } //過濾算法 function funcFilter(item,index,array){ return item>=5; } //數(shù)組順序排列 arr.sort(funcComp); alert(arr.join(',')); //0,2,5,7,9,11 //篩選數(shù)組 var arrFilter=arr.filter(funcFilter); alert(arr.join(‘,')) //5,7,9,11
3,DOM元素事件定義
<html><title></title> <body><input type=”button” value=”ClickMe” id=”myBtn” > <script type=”text/javascript> var btnClick=document.getElementById(“myBtn”); //測(cè)試環(huán)境為FireFox btnClick. addEventListener(“click”,function(e){ alert(“I'm a button!”); //I'm a button},false); </script> </body> </html>
在以上示例中,文檔中定義了一個(gè)id為myBtn的按鈕,js腳本為其添加了一個(gè)點(diǎn)擊事件,其中addEventListener的第二個(gè)參數(shù)是一個(gè)函數(shù)。
結(jié)束語:高階函數(shù)并不是JavaScript的專利,但絕對(duì)是JavaScript編程的利器。高階函數(shù)實(shí)際上就是對(duì)基本算法的再度抽象,我們可以利用這一點(diǎn),提高代碼的抽象度,實(shí)現(xiàn)最大限度的代碼重用,編寫出更簡(jiǎn)潔、更利于重構(gòu)的代碼。
相關(guān)文章
用js實(shí)現(xiàn)的檢測(cè)瀏覽器和系統(tǒng)的函數(shù)
檢測(cè)各種瀏覽器、系統(tǒng)的JS代碼2009-04-04基于Cesium實(shí)現(xiàn)衛(wèi)星在軌繞行動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了如何利用Cesium實(shí)現(xiàn)衛(wèi)星在軌繞行動(dòng)畫,文中的示例代碼講解詳細(xì),對(duì)我們了解Cesium有一定的幫助,感興趣的可以嘗試一下2022-06-06typeScript?核心基礎(chǔ)之接口interface
本篇文章主要介紹?typeScript?中接口是啥?如何定義的?接口是如何進(jìn)行擴(kuò)展的以及類如何實(shí)現(xiàn)接口,接下來和小編一起進(jìn)入下面文章一起學(xué)習(xí)?typeScript?接口2022-02-02javascript中undefined與null的區(qū)別
在JavaScript中存在這樣兩種原始類型:Null與Undefined。這兩種類型常常會(huì)使JavaScript的開發(fā)人員產(chǎn)生疑惑,在什么時(shí)候是Null,什么時(shí)候又是Undefined?2015-08-08淺析JavaScript中的特殊函數(shù)及用法小結(jié)
JavaScript中的函數(shù)本質(zhì)上是一個(gè)對(duì)象,我們可以將這個(gè)對(duì)象賦值給一個(gè)變量,這就使JavaScript中的函數(shù)變得非常的靈活,現(xiàn)在就來淺看一下JavaScript中函數(shù)的一些用法,需要的朋友可以參考下2022-06-06javascript面向?qū)ο蟀b類Class封裝類庫剖析
一個(gè)從來沒有接觸過javascript的技術(shù)人員,幾小時(shí)內(nèi)就可以寫出一個(gè)簡(jiǎn)單有用的程序代碼;想寫出高性能的代碼,同樣需要具備一個(gè)高級(jí)程序員的基本素養(yǎng),javascript也是如此2013-01-01