回调函数详解参考文章:https://blog.csdn.net/itcodexy/article/details/111027346
1. 什么是回调函数
- 被作为参数传递到另一个函数(主函数)的那个函数就叫做 回调函数。
- 回调函数就是 将这个函数作为一个参数传到另一个主函数里面,当主函数执行完之后,再执行传进去的作为参数的函数。
- 回调函数是自己定义的
- 回调函数不是自己调用
- 如果代码立即被执行就称为同步回调,如果之后的某个时间再执行,则称为异步回调。
1.1 同步回调
理解:立即执行,完全执行完了才结束,不会放入回调队列中,会阻塞调用方。主程序A会因回调函数C的执行而阻塞
例1:A.B(参数,回调函数C),主程序A调用函数B,并传入回调函数C,主程序A会等待回调函数C执行完成
例2:forEach中的回调函数执行完(不会放入队列中,一上来就执行),才会执行后面的操作
打印结果:
1.2 异步回调
理解:不会立即执行,会放入回调队列中将来执行,不会阻塞调用方。回调函数C的执行不会阻塞调用方A。
例1:A.B(参数,回调函数C)。把回调函数C放到另一个线程(进程)、甚至另一台机器上,因此回调函数的执行和我们主程序A的运行同时进行。
例2:setTimeout()内的是回调函数,会放入队列将来执行,故先执行了其后面的内容。
打印结果:
2. 回调函数的缺点
(1)问题:回调地狱
当我们有很多请求,并且下一个请求要依赖上一个请求的结果,这样会导致我们的请求
层层嵌套,使得代码非常臃肿,可读性差,容易产生bug,导致所谓的回调地狱。
回调地狱的根本问题就是:
- 嵌套函数存在耦合性,一旦有所改动,就会牵一发而动全身
- 嵌套函数一多,就很难处理错误
(2)解决:使用Promise的then方法