亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Javascript 高階函數(shù)使用介紹

 更新時間:2015年06月15日 17:28:20   投稿:mdxy-dxy  
這篇文章主要介紹了Javascript 高階函數(shù)使用介紹,需要的朋友可以參考下

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

一、參數(shù)為函數(shù)的高階函數(shù):

function funcTest(f){  
//簡易判斷一下實參是否為函數(shù)
if((typeof f)==”function”){
f();
}}
funcTest(function(){ });

這是一個簡易的將參數(shù)作為函數(shù)的高階函數(shù)。在調(diào)用funcTest時,輸入一個函數(shù)作為參數(shù),在funcTest內(nèi)部執(zhí)行這個輸入的匿名函數(shù),當然這樣的代碼片段沒有什么實際意義。

一、返回值為函數(shù)的高階函數(shù):

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

調(diào)用funcTest返回一個函數(shù)。

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

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

以上示例實現(xiàn)了一個String類型相加與Number類型相加的分離。調(diào)用add函數(shù)如果輸入?yún)?shù)為”string”時,輸出一個字符串拼接函數(shù);如果輸入?yún)?shù)為”int”則輸出數(shù)字相加函數(shù)。

三、高階函數(shù)的實際作用:

上面的代碼示例基本說明什么是高階函數(shù),下面來看看高階函數(shù)與我們實際編程有什么關系:

1,回調(diào)函數(shù)

function callback(value){
alert(value);
}
function funcTest(value,f)
//f實參檢測,檢查f是否為函數(shù) 
if(typeof callback==='function'){
f(value);}}funcTest(‘1',callback);
//1

示例在當調(diào)用funcTest時,funcTest內(nèi)部會調(diào)用callback函數(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”);
//測試環(huán)境為FireFox
btnClick. addEventListener(“click”,function(e){
alert(“I'm a button!”);
//I'm a button},false);
</script>
</body>
</html>

在以上示例中,文檔中定義了一個id為myBtn的按鈕,js腳本為其添加了一個點擊事件,其中addEventListener的第二個參數(shù)是一個函數(shù)。

結束語:高階函數(shù)并不是JavaScript的專利,但絕對是JavaScript編程的利器。高階函數(shù)實際上就是對基本算法的再度抽象,我們可以利用這一點,提高代碼的抽象度,實現(xiàn)最大限度的代碼重用,編寫出更簡潔、更利于重構的代碼。

相關文章

  • 用js實現(xiàn)的檢測瀏覽器和系統(tǒng)的函數(shù)

    用js實現(xiàn)的檢測瀏覽器和系統(tǒng)的函數(shù)

    檢測各種瀏覽器、系統(tǒng)的JS代碼
    2009-04-04
  • 基于Cesium實現(xiàn)衛(wèi)星在軌繞行動畫

    基于Cesium實現(xiàn)衛(wèi)星在軌繞行動畫

    這篇文章主要為大家詳細介紹了如何利用Cesium實現(xiàn)衛(wèi)星在軌繞行動畫,文中的示例代碼講解詳細,對我們了解Cesium有一定的幫助,感興趣的可以嘗試一下
    2022-06-06
  • Typescript使用修飾器混合方法到類的實例

    Typescript使用修飾器混合方法到類的實例

    這篇文章主要介紹了Typescript使用修飾器混合方法到類的實例,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • typeScript?核心基礎之接口interface

    typeScript?核心基礎之接口interface

    本篇文章主要介紹?typeScript?中接口是啥?如何定義的?接口是如何進行擴展的以及類如何實現(xiàn)接口,接下來和小編一起進入下面文章一起學習?typeScript?接口
    2022-02-02
  • javascript中undefined與null的區(qū)別

    javascript中undefined與null的區(qū)別

    在JavaScript中存在這樣兩種原始類型:Null與Undefined。這兩種類型常常會使JavaScript的開發(fā)人員產(chǎn)生疑惑,在什么時候是Null,什么時候又是Undefined?
    2015-08-08
  • JavaScript獲取URL匯總

    JavaScript獲取URL匯總

    在WEB開發(fā)中,許多開發(fā)者都比較喜歡使用javascript來獲取當前url網(wǎng)址,本文就此為大家總結一下比較常用獲取URL的javascript實現(xiàn)代碼
    2015-06-06
  • 淺析JavaScript中的特殊函數(shù)及用法小結

    淺析JavaScript中的特殊函數(shù)及用法小結

    JavaScript中的函數(shù)本質(zhì)上是一個對象,我們可以將這個對象賦值給一個變量,這就使JavaScript中的函數(shù)變得非常的靈活,現(xiàn)在就來淺看一下JavaScript中函數(shù)的一些用法,需要的朋友可以參考下
    2022-06-06
  • js 與或運算符 || && 妙用

    js 與或運算符 || && 妙用

    js 與或運算符 || && 妙用,可用于精簡代碼,降低程序的可讀性。
    2009-12-12
  • 一個很有趣3D球狀標簽云兼容IE8

    一個很有趣3D球狀標簽云兼容IE8

    一個很有趣的標簽云兼容 IE 8親測可用,不是基于jQuery的,所以不需要引入,下面是具體的代碼實現(xiàn)
    2014-08-08
  • javascript面向?qū)ο蟀b類Class封裝類庫剖析

    javascript面向?qū)ο蟀b類Class封裝類庫剖析

    一個從來沒有接觸過javascript的技術人員,幾小時內(nèi)就可以寫出一個簡單有用的程序代碼;想寫出高性能的代碼,同樣需要具備一個高級程序員的基本素養(yǎng),javascript也是如此
    2013-01-01

最新評論