温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

js中回调函数怎么用

发布时间:2021-09-17 11:08:38 来源:亿速云 阅读:232 作者:小新 栏目:web开发

这篇文章主要为大家展示了“js中回调函数怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“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 apple shopping 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中回调函数怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js
AI