javascript - 回調(diào)函數(shù)和普通調(diào)用函數(shù)的區(qū)別?
問題描述
回調(diào)函數(shù)的定義是將b函數(shù)當(dāng)做參數(shù)傳給a去執(zhí)行,此時(shí)b就是回調(diào)函數(shù),我突然有個(gè)疑問,它和a函數(shù)里直接調(diào)用b有什么區(qū)別呢?我自己寫了個(gè)demo
function a(){ b(); console.log(’hello world’);}function b(){ var n = 0; for(var i = 0;i < 1000000000;i++){n++; } return n;}a(); //hello world
大概3秒鐘才能看到輸出結(jié)果,然后改寫為回調(diào)函數(shù)的形式
function a(callback){ callback.call(this); console.log(’hello world’);}function b(){ var n = 0; for(var i = 0;i < 1000000000;i++){ } console.log(1);}a(b); //hello world
也是3秒后才能看到輸出結(jié)果找了很多文章,都說明了當(dāng)b作為a函數(shù)的回調(diào)函數(shù)執(zhí)行時(shí),并不妨礙a函數(shù)的正常執(zhí)行,按照這個(gè)邏輯,第二種方式應(yīng)該是立即輸出hello world的,難道是我回調(diào)函數(shù)用錯(cuò)了嗎?還是理解有問題?
問題解答
回答1:1.性能沒有區(qū)別2.回調(diào)函數(shù)是作為參數(shù)傳遞的,操作更加靈活,比如,你可以定義一個(gè)函數(shù)c,那可以運(yùn)行 b(c),當(dāng)你在函數(shù)內(nèi)運(yùn)行函數(shù)的時(shí)候,就失去了變量的靈活性。
回答2:嗯,是你理解錯(cuò)了,調(diào)用的效果是一樣的。還有 callback.call(this); 畫蛇添足,跟 callback() 的 this 是一樣的。
回調(diào)的好處是依賴倒置,不用修改 a 的代碼就可以讓 a 調(diào)用 c、d、e....
相關(guān)文章:
1. 求大神支招,php怎么操作在一個(gè)html文件的<head>標(biāo)記內(nèi)添加內(nèi)容?2. 安裝了“PHP工具箱”,但只能以“游客”身份登錄3. 老師們php,插入數(shù)據(jù)庫mysql,都是空的,要怎么解決4. 跨類調(diào)用后,找不到方法5. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?6. 致命錯(cuò)誤: Class ’appfacadeTest’ not found7. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項(xiàng)8. PHP類屬性聲明?9. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。10. phpstady在win10上運(yùn)行
