首頁  >  文章  >  web前端  >  Javascript 高階函數使用介紹_javascript技巧

Javascript 高階函數使用介紹_javascript技巧

WBOY
WBOY原創
2016-05-16 15:55:001317瀏覽

高階函數(higher-order function)—如果一個函數接收的參數為或傳回的值為函數,那麼我們可以將這個函數稱為高階函數。眾所周知,JavaScript是一種弱型別的語言:JavaScript的函數既不對輸入的參數,也不對函數的輸出值作強定義和型別檢查,那麼函數可以成為參數,也可以成為輸出值,這就體現了JavaScript對高階函數的原生支援。

一、參數為函數的高階函數:

function funcTest(f){  
//简易判断一下实参是否为函数
if((typeof f)==”function”){
f();
}}
funcTest(function(){ });

這是一個簡易的將參數作為函數的高階函數。在呼叫funcTest時,輸入一個函數作為參數,在funcTest內部執行這個輸入的匿名函數,當然這樣的程式碼片段沒有什麼實際意義。

一、傳回值為函數的高階函數:

function funcTest(){
return function(){};
}
var f=funcTest();

呼叫funcTest回傳一個函數。

二、一個複雜一點的例子:

//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

以上範例實作了一個String型別相加與Number型別相加的分離。呼叫add函數如果輸入參數為”string”時,輸出一個字串拼接函數;如果輸入參數為”int”則輸出數字相加函數。

三、高階函數的實際作用:

上面的程式碼範例基本上說明什麼是高階函數,以下來看看高階函數與我們實際程式設計有什麼關係:

1,回呼函數

function callback(value){
alert(value);
}
function funcTest(value,f)
//f实参检测,检查f是否为函数 
if(typeof callback==='function'){
f(value);}}funcTest(‘1',callback);
//1

範例在當呼叫funcTest時,funcTest內部會呼叫callback函數,即實現回呼。

2,資料篩選與排序演算法

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;
}
//数组顺序排列
arr.sort(funcComp);
alert(arr.join(','));
//0,2,5,7,9,11
//筛选数组
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”);
//测试环境为FireFox
btnClick. addEventListener(“click”,function(e){
alert(“I'm a button!”);
//I'm a button},false);
</script>
</body>
</html>

在上述範例中,文件中定義了一個id為myBtn的按鈕,js腳本為其新增了一個點擊事件,其中addEventListener的第二個參數是一個函數。

結論:高階函數並不是JavaScript的專利,但絕對是JavaScript程式設計的利器。高階函數其實就是對基本演算法的再度抽象化,我們可以利用這一點,提高程式碼的抽象度,實現最大限度的程式碼重用,編寫出更簡潔、更利於重構的程式碼。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn