JavaScript中的回调函数

Posted 提升自己,才有选择的能力和勇气

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript中的回调函数相关的知识,希望对你有一定的参考价值。

回调的英文定义:A callback is a function that is passed as an argument to another function and is executed after its parent function has completed。

字面上的理解,回调函数就是一个参数,将这个函数作为参数传到另一个函数里面,当那个函数执行完之后,再执行传进去的这个函数。这个过程就叫做回调。

回调,就是回头调用的意思。主函数的事先干完,回头再调用传进来的那个函数。

举一个别人举过的例子:约会结束后你送你女朋友回家,离别时,你肯定会说:“到家了给我发条信息,我很担心你。” 对不,然后你女朋友回家以后还真给你发了条信息。小伙子,你有戏了。其实这就是一个回调的过程。你留了个参数函数(要求女朋友给你发条信息)给你女朋友,然后你女朋友回家,回家的动作是主函数。她必须先回到家以后,主函数执行完了,再执行传进去的函数,然后你就收到一条信息了。

用代码说话。

//定义主函数,回调函数作为参数
function A(callback) {
    callback();  
    console.log(‘我是主函数‘);      
}

//定义回调函数
function B(){
    setTimeout("console.log(‘我是回调函数‘)", 3000);//模仿耗时操作  
}

//调用主函数,将函数B传进去
A(B);

//输出结果
我是主函数
我是回调函数

上面的代码中,我们先定义了主函数和回调函数,然后再去调用主函数,将回调函数传进去。

定义主函数的时候,我们让代码先去执行callback()回调函数,但输出结果却是后输出回调函数的内容。

这就说明了主函数不用等待回调函数执行完,可以接着执行自己的代码。所以一般回调函数都用在耗时操作上面。比如ajax请求,比如处理文件等

 

对普通函数的调用:调用程序发出对普通函数的调用后,程序执行立即转向被调用函数执行,直到被调用函数执行完毕后,再返回调用程序继续执行

对回调函数的调用:调用程序发出对回调函数的调用后,不必等函数执行完毕,立即返回并继续执行。

 

文章引用IT男青年博客:https://blog.csdn.net/linshichen/article/details/78327278

以上是关于JavaScript中的回调函数的主要内容,如果未能解决你的问题,请参考以下文章

jquery中的回调函数怎么用

JavaScript中的回调函数

浅谈JavaScript中的异步处理

理解JavaScript中的回调函数

Javascript中的回调函数和匿名函数的回调

Javascript 中的回调函数和递归函数简单实际分析学习