JavaScript回調函數(shù)callback用法解析
這篇文章主要介紹了JavaScript回調函數(shù)callback用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
JavaScript回調函數(shù)的使用是很常見的,引用官方回調函數(shù)的定義:
A callback is a function that is passed as an argument to another function and is executed after its parent function has completed.
解釋得很明確,回調函數(shù)就是作為參數(shù)傳遞給另一個函數(shù)并在其父函數(shù)完成后執(zhí)行的函數(shù)。
聽起來似乎有點不好理解,所以還是舉例進行說明,介紹回調函數(shù)之前先簡單說明一下同步和異步,前端也有同步和異步。同步和異步總得來說,兩者最明顯的區(qū)別就是是否需要等待,如果是串行執(zhí)行的就是同步機制,是并行執(zhí)行的就是異步機制,這個比較好理解
回調函數(shù)的使用并沒有同步和異步的區(qū)別,回調函數(shù)只是一種特殊的函數(shù),可以應用于同步調用場景,也可以應用于異步調用場景
異步請求中的回調函數(shù)
最常用的有ajax異步調用或者事件機制,例子:
$.get('${root}/saveOrUpdate.do',function(result){ alert(result); });
同步請求中的回調函數(shù)
業(yè)務場景:舉個例子,點擊按鈕會觸發(fā)main函數(shù),進行接口數(shù)據(jù)保存(異步方式),數(shù)據(jù)保存成功之后,再回調打開彈窗的函數(shù)
保存數(shù)據(jù)函數(shù):
function saveRecord(seq,callback){ $.ajax({ url:'${root}/saveOrUpdate.do', type:"post", async:true, success:function(result){ //確保callback是一個函數(shù)類型的 if(typeof(callback)==='function'){ callback(true); } } }); }
main函數(shù)
//保存成功,才會打開彈窗 function main(seq){ saveRecord(seq,callbackFunction); }
回調函數(shù),數(shù)據(jù)保存成功后再調用
/*保存時的回調函數(shù)*/ function callbackFunction(saveSuccess){ if(saveSuccess){ //省略打開彈窗代碼 } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
javascript加載xml 并解析各節(jié)點的值(實現(xiàn)方法)
下面小編就為大家?guī)硪黄猨avascript加載xml 并解析各節(jié)點的值(實現(xiàn)方法)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10使用postMesssage()實現(xiàn)跨域iframe頁面間的信息傳遞方法
下面小編就為大家?guī)硪黄褂胮ostMesssage()實現(xiàn)跨域iframe頁面間的信息傳遞方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家一個參考。一起跟隨小編過來看看吧2016-03-03