JS回调函数原理与用法详解【附PHP回调函数】


Posted in Javascript onJuly 20, 2019

本文实例讲述了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
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都是差不多的,都是先定义好函数,然后需要的时候就调用过来。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
推荐一些非常不错的javascript学习资源站点
Aug 29 Javascript
基于jquery的图片懒加载js
Jun 30 Javascript
基于jquery的DIV随滚动条滚动而滚动的代码
Jul 20 Javascript
json+jQuery实现的无限级树形菜单效果代码
Aug 27 Javascript
学习JavaScript正则表达式
Nov 13 Javascript
基于Jquery实现仿百度百科右侧导航代码附源码下载
Nov 27 Javascript
JS实现添加,替换,删除节点元素的方法
Jun 30 Javascript
Websocket协议详解及简单实例代码
Dec 12 Javascript
分享Bootstrap简单表格、表单、登录页面
Aug 04 Javascript
JavaScript实现数组全排列、去重及求最大值算法示例
Jul 30 Javascript
vue-cli3 取消eslint校验代码的解决办法
Jan 16 Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
Jul 31 Javascript
JavaScript展开操作符(Spread operator)详解
Jul 20 #Javascript
JavaScript剩余操作符Rest Operator详解
Jul 20 #Javascript
微信小程序点击图片实现长按预览、保存、识别带参数二维码、转发等功能
Jul 20 #Javascript
基于vue 实现表单中password输入的显示与隐藏功能
Jul 19 #Javascript
el-input 标签中密码的显示和隐藏功能的实例代码
Jul 19 #Javascript
Android 自定义view仿微信相机单击拍照长按录视频按钮
Jul 19 #Javascript
使用element-ui的el-menu导航选中后刷新页面保持当前选中状态
Jul 19 #Javascript
You might like
Access数据库导入Mysql的方法之一
2006/10/09 PHP
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php调用mysql存储过程实例分析
2014/12/29 PHP
Javascript Function对象扩展之延时执行函数
2010/07/06 Javascript
IE中jquery.form中ajax提交没反应解决方法分享
2012/09/11 Javascript
JQUERY 实现窗口滚动搜索框停靠效果(类似滚动停靠)
2013/03/27 Javascript
JS父页面与子页面相互传值方法
2014/03/05 Javascript
javascript实现的一个带下拉框功能的文本框
2014/05/08 Javascript
JavaScript中的变量定义与储存介绍
2014/12/31 Javascript
详解AngularJS实现表单验证
2015/12/10 Javascript
基于JQuery及AJAX实现名人名言随机生成器
2017/02/10 Javascript
详解在Vue中如何使用axios跨域访问数据
2017/07/07 Javascript
vue 封装 Adminlte3组件的实现
2020/03/18 Javascript
python实现的阳历转阴历(农历)算法
2014/04/25 Python
在Python中使用HTMLParser解析HTML的教程
2015/04/29 Python
在Python中移动目录结构的方法
2016/01/31 Python
python用pickle模块实现“增删改查”的简易功能
2017/06/07 Python
对Python中画图时候的线类型详解
2019/07/07 Python
python实现连连看辅助(图像识别)
2020/03/25 Python
通过实例了解Python str()和repr()的区别
2020/01/17 Python
Pytorch maxpool的ceil_mode用法
2020/02/18 Python
python3.6中anaconda安装sklearn踩坑实录
2020/07/28 Python
英国时尚饰品和发饰购物网站:Claire’s
2017/07/04 全球购物
美国最大的香水出口:FragranceX.com
2017/11/04 全球购物
八一建军节部队活动方案
2014/02/04 职场文书
机关节能减排实施方案
2014/03/17 职场文书
幼儿园教研活动总结
2014/04/30 职场文书
公司委托书怎么写
2014/08/02 职场文书
2014年九一八事变演讲稿
2014/09/14 职场文书
法人授权委托书范本
2014/09/17 职场文书
2015年爱牙日活动总结
2015/03/23 职场文书
导游词之吉林花园山
2019/10/17 职场文书
JavaScript使用canvas绘制坐标和线
2021/04/28 Javascript
js实现自动锁屏功能
2021/06/02 Javascript
通过shell脚本对mysql的增删改查及my.cnf的配置
2021/07/07 MySQL
VUE中的v-if与v-show区别介绍
2022/03/13 Vue.js