概述
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.length
,node.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中回调函数(详解分享)的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是花痴身影为你收集整理的深入解析js中回调函数(详解分享)的全部内容,希望文章能够帮你解决深入解析js中回调函数(详解分享)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复