在前端開發中,回調函數是一個非常重要的概念,我們經常會在項目中使用到它,但對于一些初學者來說比較難以理解,今天小千就來給大家介紹一下回調函數的概念和使用,千萬不要錯過了。
回調函數的概念
什么是回調函數?
一個被當做參數的函數,即為回調函數。
首先我們要清楚一個概念,在JS中萬物皆為對象。函數本身也是一個對象,既然是對象,所以函數當然可以當做函數的參數。
如上述代碼,fun函數就是一個對象。
上述代碼中,fun2做為fun1的參數,fun2即為回調函數。
在這里肯定會有小伙伴有疑問,為什么在fun1中不去直接調用fun2,而是通過回調函數進行傳參?下一小節,我們將詳細討論這個問題。
回調函數的作用
幾乎所有的第三方函數我們都無法修改函數的內部實現, 比如數組的forEach,map等。那么我們也就無法在這樣的函數體中,調用自己所寫的功能模塊。所以此時,回調函數就提供了這樣的能力,使我們可以將自己所書寫的函數傳入第三方函數中,從而實現完整的功能。
回調函數的使用
下面我們將通過冒泡排序,來展示回調函數的使用方式。
函數bubbleSort擁有一個參數callBack,而smallToLarge與LargeTosmall均為回調函數,當我們在bubbleSort函數調用時,傳入smallToLarge與LargeTosmall就可以非常方便的控制排序的規則。
想學習web前端的同學,可以參考千鋒web前端培訓班提供的web前端學習路線,該學習路線對從零基礎小白到web前端初級開發工程師,web前端高級開發工程師,后面的web前端大神級開發工程師都有一個明確清晰的指導,根據千鋒web前端培訓機構提供的web前端學習路線圖可以讓你對學習web前端開發需要掌握的知識有個清晰的了解,并快速入門web前端開發。想要獲取前端完整學習路線和免費的學習資料可以添加我們的web前端技術分享交流qq群:857920838 加群找群管理領取即可,等你來哦~~