

闭包与回调
下面看一道闭包的题目,分别点击第一个和第四个节点,执行结果:
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
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");
//其实就原理来说,JS和php都是差不多的,都是先定义好函数,然后需要的时候就调用过来。
更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
