javascript - 回調(diào)函數(shù)和普通調(diào)用函數(shù)的區(qū)別?
問題描述
回調(diào)函數(shù)的定義是將b函數(shù)當做參數(shù)傳給a去執(zhí)行,此時b就是回調(diào)函數(shù),我突然有個疑問,它和a函數(shù)里直接調(diào)用b有什么區(qū)別呢?我自己寫了個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秒鐘才能看到輸出結果,然后改寫為回調(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秒后才能看到輸出結果找了很多文章,都說明了當b作為a函數(shù)的回調(diào)函數(shù)執(zhí)行時,并不妨礙a函數(shù)的正常執(zhí)行,按照這個邏輯,第二種方式應該是立即輸出hello world的,難道是我回調(diào)函數(shù)用錯了嗎?還是理解有問題?
問題解答
回答1:1.性能沒有區(qū)別2.回調(diào)函數(shù)是作為參數(shù)傳遞的,操作更加靈活,比如,你可以定義一個函數(shù)c,那可以運行 b(c),當你在函數(shù)內(nèi)運行函數(shù)的時候,就失去了變量的靈活性。
回答2:嗯,是你理解錯了,調(diào)用的效果是一樣的。還有 callback.call(this); 畫蛇添足,跟 callback() 的 this 是一樣的。
回調(diào)的好處是依賴倒置,不用修改 a 的代碼就可以讓 a 調(diào)用 c、d、e....
相關文章:
1. boot2docker無法啟動2. docker-compose中volumes的問題3. node.js - antdesign怎么集合react-redux對input控件進行初始化賦值4. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.5. 關于docker下的nginx壓力測試6. java - SSH框架中寫分頁時service層中不能注入分頁類7. dockerfile - 為什么docker容器啟動不了?8. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””9. 老師,按tab鍵不起作用怎么回事10. mac里的docker如何命令行開啟呢?

網(wǎng)公網(wǎng)安備