av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - 回調函數和普通調用函數的區別?

瀏覽:102日期:2023-06-04 11:16:41

問題描述

回調函數的定義是將b函數當做參數傳給a去執行,此時b就是回調函數,我突然有個疑問,它和a函數里直接調用b有什么區別呢?我自己寫了個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秒鐘才能看到輸出結果,然后改寫為回調函數的形式

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函數的回調函數執行時,并不妨礙a函數的正常執行,按照這個邏輯,第二種方式應該是立即輸出hello world的,難道是我回調函數用錯了嗎?還是理解有問題?

問題解答

回答1:

1.性能沒有區別2.回調函數是作為參數傳遞的,操作更加靈活,比如,你可以定義一個函數c,那可以運行 b(c),當你在函數內運行函數的時候,就失去了變量的靈活性。

回答2:

嗯,是你理解錯了,調用的效果是一樣的。還有 callback.call(this); 畫蛇添足,跟 callback() 的 this 是一樣的。

回調的好處是依賴倒置,不用修改 a 的代碼就可以讓 a 調用 c、d、e....

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲一区综合 | 青青草原综合久久大伊人精品 | 欧美日韩高清一区二区三区 | 国产极品粉嫩美女呻吟在线看人 | 日韩久久久久久 | 国产精品久久久久免费 | 精品国产精品国产偷麻豆 | 日韩一区二区在线视频 | 国产精品美女久久久久久免费 | 欧美天堂| 国产一区视频在线 | 国产精品久久一区二区三区 | 美日韩中文字幕 | 国产亚洲一区精品 | 亚洲激情一区二区 | 亚洲高清视频在线观看 | 国产欧美一区二区三区另类精品 | 国产久| 亚洲在线一区二区 | 91传媒在线播放 | 欧美国产精品一区二区三区 | 亚洲成人蜜桃 | 国产免费看 | 国产一区不卡 | 亚洲精品v | 久久99精品久久久久蜜桃tv | 国产区精品在线观看 | 欧美极品在线播放 | 国产免费一级片 | 中文字幕在线观看一区 | 午夜爱爱毛片xxxx视频免费看 | 久久久久久国产免费视网址 | 精品国产一区二区三区久久 | 欧美视频三区 | 日韩福利在线观看 | 999久久久国产精品 欧美成人h版在线观看 | 91.xxx.高清在线 | 亚洲自拍偷拍免费视频 | 久操伊人 | 99福利在线观看 | 欧美一级片中文字幕 |