A. jQuery中方法回調函數什麼用
函數處理返回來的數據,比如以下代碼是把返回的數據添加到列表中
$.ajax(
{
type: "get",
datatype: "json",
url: encodeURI("test.ashx?name=" + $("#<%=TextBox1.ClientID %>").val()),
beforeSend: function() { $("#panel").html("正在載入..."); },
success: function(data) { var data1 = eval('' + data + ''); $("#panel").html(""); $.each(data1, function(i) { $("#panel").append("<li>name:" + data1[i].name + " " + "age:" + data1[i].age + "</li>"); }) },
// success:function(data){$("#panel").html(data);},
complete: function() { alert("載入完成"); }
}
)
B. 什麼是回調函數
回調函數就是一個通過函數指針調用的函數。
如果把函數的指針(地址)作為參數傳遞給另一個函數,當這個指針被用來調用其所指向的函數時,那就說這是回調函數。回調函數不是由該函數的實現方直接調用,而是在特定的事件或條件發生時由另外的一方調用的,用於對該事件或條件進行響應。
不管怎麼說,回調函數是繼承自C語言的。在C++中,應只在與C代碼建立介面或與已有的回調介面打交道時,才使用回調函數。除了上述情況,在C++中應使用虛擬方法或仿函數(functor),而不是回調函數。
(2)text回調函數有什麼用擴展閱讀
回調函數的好處:
1、回調函數可以把調用者與被調用者分開,所以調用者不關心誰是被調用者。它只需知道存在一個具有特定原型和限制條件的被調用函數。簡而言之,回調函數就是允許用戶把需要調用的函數的指針作為參數傳遞給一個函數,以便該函數在處理相似事件的時候可以靈活的使用不同的方法。
2、回調可用於通知機制。例如,有時要在A程序中設置一個計時器,每到一定時間,A程序會得到相應的通知,但通知機制的實現者對A程序一無所知。那麼,就需一個具有特定原型的函數指針進行回調,通知A程序事件已經發生。實際上,API使用一個回調函數SetTimer()來通知計時器。
C. c語言回調函數究竟有什麼用處我覺的用普通的函數調用替換也可以,謝謝
從功抄能上來說 普通函數也是可以襲的
但在比較大的程序設計中 會對很多功能模塊進行封裝
比如 上層一個模塊
底層一個模塊
同時規定,上層可以調用底層的函數,但是底層不可以調用上層函數。
這時就需要使用回調函數。
通過上層調用底層的注冊回調借口,傳入回調指針。
實現底層通知上層的作用。
另外 回調函數的一個好處是,可以通過回調函數,調用不同介面。
比如接收數據,不同數據需要不同的解析函數。
但是接收數據的流程是相同的
這樣 使用回調函數,在接收數據的時候就可以不用判斷,而是自動使用不同的解析函數。
總之 使用回調函數,可以降低耦合,實現多樣性。
D. 什麼是回調函數
回調函數就是一個通過函數指針調用的函數 希望我的回答能夠幫到你
E. 什麼叫回調函數,與一般的函數有什麼區別,我
函數調用形式本身沒有好壞之分
任何函數代碼如果有錯誤都可能導致軟體出問題,甚至導致崩潰
c 里可以使用指針,函數指針
這就使程序可以更靈活
當 函數指針 做為函數的參數,傳遞給一個被調用函數,
被調用函數就可以通過這個指針調用外部的函數,這就形成了回調
windows程序中 WndProc 就是使用回調的典型形式
一般的程序中回調函數作用不是非常明顯,可以不使用這種形式
最主要的用途就是當函數不處在同一個文件當中,比如動態庫,要調用
其他程序中的函數就只有採用回調的形式
#include "stdio.h"
#include "conio.h"
int add(int a, int b);
int libfun(int (*pDis)(int a, int b));
int main(void)
{
int (*pfun)(int a, int b);
pfun = add;
libfun(pfun);
}
int add(int a, int b)
{
return a + b;
}
int libfun(int (*pDis)(int a, int b))
{
int a, b;
a = 1;
b = 2;
printf("%d", pDis(a, b));
}
現在這幾個函數是在同一個文件當中
假如
int libfun(int (*pDis)(int a, int b))
是一個庫中的函數,就只有使用回調了,通過函數指針參數將外部函數地址傳入
來實現調用
函數 add 的代碼作了修改,也不必改動庫的代碼,就可以正常實現調用
便於程序的維護和升級
F. 什麼是JavaScript中的回調函數,作用是什麼
var req;
function validate() {
var idField = document.getElementById("userid");
var url = "Validate.jsp?id=" + encodeURI(idField.value);
init();
req.open("GET", url, true);
req.onreadystatechange = callback;
//callback就是回調函數,當觸發req.onreadystatechange時,調用callback獲取url傳回的東西
req.send(null);
}
function init() {
if(window.XMLHttpRequest) {
req = new XMLHttpRequest();
} else if (window.ActiveXObject) {
req = new ActiveXObject("Microsoft.XMLHTTP");
}
}
function callback() {
if(req.readyState == 4) { //反饋回到客戶端
if(req.status == 200) { //反饋完全正常
//alert(req.responseText);
var msg = req.responseXML.getElementsByTagName("msg")[0];
//alert(msg);
setMsg(msg.childNodes[0].nodeValue);
}
}
}
function setMsg(msg) {// 頁面中的span <span id="usermsg"></span>
//alert(msg);
mdiv = document.getElementById("usermsg");
if(msg == "invalid") {
mdiv.innerHTML = "<font color='red'>username exists</font>";
} else {
mdiv.innerHTML = "<font color='green'>congratulations! you can use this username!</font>";
}
}
Validate.jsp
<%
response.setContentType("text/xml");
response.setHeader("Cache-Control", "no-store"); //HTTP1.1
response.setHeader("Pragma", "no-cache"); //HTTP1.0
response.setDateHeader("Expires", 0); //prevents catching at proxy server
System.out.println(request.getParameter("id"));
//check the database 可以先去資料庫取
response.getWriter().write("<msg>valid</msg>");//寫這個內容,隨便指定
%>
G. c++回調函數有什麼用
回調類似於事件相應。當系統在某個事情發生的時候會調用你指定的方法。這個方法先定義好,並等待系統來調用。比如Hook(系統鉤子)就是給窗口設置一個函數地址,然後系統會自動的調用你的函數。這就是回調了。
H. 回調函數的作用 請用自己的話說明!!
回調函數就是那些自己寫的,但是不是自己來調,而是給別人來掉的函數。
消息響應函數版就可以看成是回調函數,因權為是讓系統在合適的時候去調用。這不過消息響應函數就是為了處理消息的,所以就拿出來單做一類了。其實本質上就是回調函數。
但是回調函數不是只有消息響應函數一種,比如在內核編程中,驅動程序就要提供一些回調函數,當一個設備的數據讀寫完成後,讓系統調用這些回調函數來執行一些後續工作。
回調函數賦予程序員這樣一種能力,讓自己編寫的代碼能夠跳出正常的程序控制流,適應具體的運行環境在正確的時間執行。
I. 怎麼理解回調函數回調函數有什麼好處
你就想像你函數的一部分功能被外包給別人。至於被人怎麼實現的你不用管,你的函數具有一個完整的功能,但是有的功能可以隨你自己定製,參照stl中的for_each
J. js回調函數有什麼用
很容易把一個函數作為參數傳遞。
functionfn(arg1,arg2,callback){
varnum=Math.ceil(Math.random()*(arg1-arg2)+arg2);
callback(num);//傳遞結果
}
fn(10,20,function(num){
console.log("Callbackcalled!Num:"+num);
});//結果為10和20之間的隨機數
可能這樣做看起比較麻煩,甚至有點愚蠢,為何不正常地返回結果?但是當遇上必須使用回調函數之時,你也許就不這樣認為了!
傳統函數以參數形式輸入數據,並且使用返回語句返回值。理論上,在函數結尾處有一個return返回語句,結構上就是:一個輸入點和一個輸出點。這比較容易理解,函數本質上就是輸入和輸出之間實現過程的映射。
但是,當函數的實現過程非常漫長,你是選擇等待函數完成處理,還是使用回調函數進行非同步處理呢?這種情況下,使用回調函數變得至關重要,例如:AJAX請求。若是使用回調函數進行處理,代碼就可以繼續進行其他任務,而無需空等。實際開發中,經常在javascript中使用非同步調用,甚至在這里強烈推薦使用!
下面有個更加全面的使用AJAX載入XML文件的示例,並且使用了call()函數,在請求對象(requested object)上下文中調用回調函數。
functionfn(url,callback){
varhttpRequest;//創建XHR
httpRequest=window.XMLHttpRequest?newXMLHttpRequest()://針對IE進行功能性檢測
window.ActiveXObject?newActiveXObject("Microsoft.XMLHTTP"):undefined;
httpRequest.onreadystatechange=function(){
if(httpRequest.readystate===4&&httpRequest.status===200){//狀態判斷
callback.call(httpRequest.responseXML);
}
};
httpRequest.open("GET",url);
httpRequest.send();
}
fn("text.xml",function(){//調用函數
console.log(this);//此語句後輸出
});
console.log(".");//此語句先輸出
我們請求非同步處理,意味著我們開始請求時,就告訴它們完成之時調用我們的函數。在實際情況中,onreadystatechange事件處理程序還得考慮請求失敗的情況,這里我們是假設xml文件存在並且能被瀏覽器成功載入。這個例子中,非同步函數分配給了onreadystatechange事件,因此不會立刻執行。
最終,第二個console.log語句先執行,因為回調函數直到請求完成才執行。