Javascript 高階函數(shù)使用介紹
高階函數(shù)(higher-order function)—如果一個(gè)函數(shù)接收的參數(shù)為或返回的值為函數(shù),那么我們可以將這個(gè)函數(shù)稱為高階函數(shù)。眾所周知,JavaScript是一種弱類型的語(yǔ)言: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é)束語(yǔ):高階函數(shù)并不是JavaScript的專利,但絕對(duì)是JavaScript編程的利器。高階函數(shù)實(shí)際上就是對(duì)基本算法的再度抽象,我們可以利用這一點(diǎn),提高代碼的抽象度,實(shí)現(xiàn)最大限度的代碼重用,編寫出更簡(jiǎn)潔、更利于重構(gòu)的代碼。
相關(guān)文章
純JS焦點(diǎn)圖特效實(shí)例(可一個(gè)頁(yè)面多用)
下面小編就為大家?guī)硪黄僇S焦點(diǎn)圖特效實(shí)例(可一個(gè)頁(yè)面多用)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-12-12
關(guān)于在Typescript中做錯(cuò)誤處理的方式詳解
錯(cuò)誤處理是軟件工程重要的一部分,如果處理得當(dāng),它可以為你節(jié)省數(shù)小時(shí)的調(diào)試和故障排除時(shí)間,我發(fā)現(xiàn)了與錯(cuò)誤處理相關(guān)的三大疑難雜癥:TypeScript的錯(cuò)誤類型,變量范圍和嵌套,讓我們逐一深入了解它們帶來的撓頭問題,感興趣的朋友可以參考下2023-09-09
javascript 冒泡排序 正序和倒序?qū)崿F(xiàn)代碼
javascript 冒泡排序 正序和倒序?qū)崿F(xiàn)代碼,需要的朋友可以參考下。2010-12-12
JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧
這篇文章給大家詳細(xì)介紹了JS是否可以跨文件同時(shí)控制多個(gè)iframe頁(yè)面的應(yīng)用技巧,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2007-12-12

