javascript的回呼函數應用樣本

來源:互聯網
上載者:User

回呼函數概念:回呼函數就是一個通過函數指標調用的函數。如果你把函數的指標(地址)作為參數傳遞給另一個函數,當這個指標被用為調用它所指向的函數時,我們就說這是回呼函數。

JS Api 裡這樣解釋:A callback is a function that is passed as an argument to another function and is executed after its parent function has completed.

使用回呼函數的原因:可以把調用者與被調用者分開。調用者不關心誰是被調用者,所有它需知道的,只是存在一個具有某種特定原型、某些限制條件(如傳回值為int)的被調用函數。

考慮一個這樣的例子:

假如某個項目的底層和高層是由不同的人員協同完成.底層負責資料的存取,高層負責資料的表示.當高層要用到某個模組的資料,於是他對底層人員說,我需要你們提供滿足某種需求的資料,你給我提供一個介面.

底層的人員說:我給你提供資料,怎麼展示和處理則是你的事情.我不可能為你每個需求都提供一個資料介面,我給你提供一個通過的介面.你得到資料,然後自己寫函數去展示.由是經過協商,雙方提供了一個這樣的介面:
複製代碼 代碼如下:
//data表示底層提供的資料來源,funcName表示高層的調用函數

function(data,funcName){

1.data屬於情形1,由底層處理;

2.data屬於情形2,由高層處理,怎麼處理呢?利用高層提供的函數funcName處理

.....

}

我可能還沒說清楚,我們看個例子一下子就明白了
複製代碼 代碼如下:
//假如提供的資料來源是一整數,為某學生的分數,當num<=0,由底層處理,當n>0時由高層處理.

//將下面這個函數拷貝下來存檔為1.js

function f(num,callback){
if(num<0) {
alert("調用低層函數處理!");
alert("分數不能為負,輸入錯誤!");
}else if(num==0){
alert("調用低層函數處理!");
alert("該學生可能未參加考試!");
}else{
alert("調用高層函數處理!");
callback();
}
}

複製代碼 代碼如下:
//將下面這個test.html檔案存檔與1.js在一個目錄下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<script src="1.js" type="text/javascript"></script>
<title>無標題文檔</title>
<script type="text/javascript">
function test(){
var p=document.getElementById("pp");
pp.innerText="";
var num=document.getElementById("score").value;
f(num,function(){ //匿名高層處理函數
if(num<60) alert("未及格!");
else if(num<=90) alert("該產生績優良!");
else alert("該產生績優秀!"); })
pp.innerText="by since1978 qq558064!"
}
</script>
</head>

<body>
<p>
回呼函數樣本:當學產生績score<=0分時候,由底層處理;當score>0時,由高層處理。
</p>
請輸入學產生績<input type="text" id="score">
<input type="button" onClick="test()" value=" 看看結果">
<p id="pp"></p>
</body>
</html>

運行此檔案,可以看到效果

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.