首页前端开发JavaScript深入解析js中回调函数(详解分享)

深入解析js中回调函数(详解分享)

时间2024-01-30 09:14:03发布访客分类JavaScript浏览560
导读:收集整理的这篇文章主要介绍了深入解析js中回调函数(详解分享),觉得挺不错的,现在分享给大家,也给大家做个参考。之前的文章《一文讲解js中this指向问题(附代码)》中,给大家介绍了解了js中this指向问题。下面本篇文章给大家了解js中回...
收集整理的这篇文章主要介绍了深入解析js中回调函数(详解分享),觉得挺不错的,现在分享给大家,也给大家做个参考。

之前的文章《一文讲解js中this指向问题(附代码)》中,给大家介绍了解了js中this指向问题。下面本篇文章给大家了解js中回调函数详解,伙伴们看看一下。

JS 回调函数详解

JS回调函数

何为回调函数,官方解释:当程序跑起来时,一般情况下,应用程序(application PRogram)会时常通过API调用库里所预先备好的函数。但是有些库函数(library function)却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务。这个被传入的、后又被调用的函数就称为回调函数(callback function)。

通常将一个函数B传入另一个函数A,并且在 需要的时候再调用函数A。

说白了,回调就是回溯,先定义好将要使用的函数体,然后在使用使再调用这个函数,我们通常把callback作为一个参数传入先定义的那个函数。下面我们先来看一段jquery代码:

$("p").hide(1000,function(){
    alert("The paragraph is now hidden");
}
    );
    

上面jquery就是一个回调函数,首先它在执行完hide效果后,接着调用function回调函数。

我们再来看一段JS代码,看看回调函数是如何实现的:

function Buy(name,goods1,callback) {
        alert(name+' buy '+goods1);
        if(callback&
    &
    tyPEof(callback)==="function")        callback();
}
Buy('xiaoming','apple',function(){
        alert("shopping finish");
}
    );
    

一个很简单的代码,一开始不知道要买啥,等到买到东西,立即把之前定义好的函数调用出来,最好加上判断规则,因为一切前提是callback必须是一个函数,输出结果为:

xiaoming buy appleshopping finish

闭包与回调

下面看一道闭包的题目,分别点击第一个和第四个节点,执行结果:

VAR nodes = document.getelementsbytagname('button');
    for (var i = 0;
     i  nodes.length;
 i++) {
    nodes[i].addEventListener('click', function() {
            console.LOG('You clicked element #' + i);
   }
    );
}
    

这里虽然主要考的是闭包,addEventListener是一个闭包,而匿名函数是一个回调函数,i是在闭包中的变量。在addEventListener的回调执行时,循环已经结束,此时的变量i被赋值为node.lengthnode.length为总节点数。所以结果就是

You clicked element # node.length

那要怎么改,将其返回值改成函数,既然i变量的值会被释放,那我们就引入i,让每次循环的值都保存在内存中,就可以了:

var nodes = document.getElementsByTagName('button');
    for (var i = 0;
     i  nodes.length;
 i++) {
(function(i) {
    nodes[i].addEventListener('click', function () {
            console.log('You clicked element #' + i);
        }
)       }
    )(i);
}
    

PHP回调函数

下面略说一下php中回调函数如何实现(结果为1,2,3,4):

?php    $array=array(1,2,3,4);
    array_walk($array,function($value){
            echo $value;
}
    );
    ?>
    

php对每个传入的数组元素作回调处理,下面再看看php的闭包,使用use关键字继承作用域外的变量:

?php    function getcouter(){
            $i=0        return function() use($i)(            echo $i;
        )}
    ;
    }
        $counter=getcounter();
        echo $counter();
        echo $counter();
    ?>
    

返回结果为:

1,1

官方php使用方法

class hello {
function callback($a,$b) {
    echo "$a,$b";
}
static function callback($c,$d){
    echo "$c,$d";
        }
}
    //将类名作为参数call_user_func(array('hello','callback'),"hello","world");
    //输出 hello,world//将对象作为参数call_user_func(array(new hello(),'callback'),"hello","world");
    //将静态方法作为参数call_user_func(hello::callback,"hello","world");
    //输出 hello,world

其实就原理来说,JS和php都是差不多的,都是先定义好函数,然后需要的时候就调用过来。

推荐学习:JS视频教程

以上就是深入解析js中回调函数(详解分享)的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 浅谈TypeScript中值得了解的7个方...下一篇:聊聊Angular+Service如何改进日志...猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: 深入解析js中回调函数(详解分享)
本文地址: https://pptw.com/jishu/592326.html
RabbitMQ基本概念和原理实例 详解用MicroService4Net 创建一个微服务的实例

游客 回复需填写必要信息