php 回调函数的作用域,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都是差不多的,都是先定义好函数,然后需要的时候就调用过来。 ------ 本文结束 ------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值