浅析JS中回调函数及用法


Posted in Javascript onJuly 25, 2018

回调函数,什么是回调函数呢?很多初学者都不是很明白,感觉懵懵的,不理解,更不会用!

其实简单理解的话就是在一个函数执行完毕后,得到想要的特定数据后在去执行的函数,并没有性药中的那么高深!

function getdata(callback){
    //这里我们假设是从后端获取数据
    setTimeout(function(){
     //假设我们获取到数据info
     var info = {
      "id":1,
      "name":'张三'
     }
     //得到数据以后执行函数方法
     callback(info)//这个就是回调函数
    },1000)

上述代码就可以清除的告诉你什么是回调函数!可能你还是不太明白,这个callback是什么,他有什么作用呢?

getdata(check)
   function getdata(callback){
    //这里我们假设是从后端获取数据
    setTimeout(function(){
     //假设我们获取到数据info
     var info = {
      "id":1,
      "name":'张三'
     }
     //得到数据以后执行函数方法
     callback(info)//这个就是回调函数
    },1000)
 }
function check(data){
  if(data.id==1){
   console.log('验证成功,可以通过')
  }
}

看上面的代码,有两个方法,getdata和check,我们执行了getdata方法,并把check当做参数传给了getdata,那么这时候check就是回调函数!

那么这个回调函数有什么作用呢,怎么用呢?如果你已经理解了回调函数的意义,那么你将很好的理解他的用法,记忆怎么在实际项目中去用他!

看下面的代码,我写的一种实际应用中的用法:

//vue框架的应用,其他框架的可以自行修改!!!
//用户权限验证实例:
created(){//在这个钩子函数中取执行获取数据的方法,将验证方法作为回调传入
  getdata(check)
 }
 methods:{//在这里面,首先你得有created钩子函数中用到的那两个方法
   function getdata(callback){//向后端请求用户信息
    //这里我们假设是从后端获取数据
    setTimeout(function(){
     //假设我们获取到数据info
     var info = {
      "id":1,
      "name":'张三'
     }
     //得到数据以后执行函数方法
     callback(info)//这个就是回调函数,得到用户信息后去验证他的权限
    },1000)
 }
function check(data){//验证用户权限
  if(data.id==1){//验证权限的条件,根据实际设定
   console.log('验证成功,可以通过')//权限通过,可以做什么
  }else{
   console.log('验证失败,禁止通行')//没有权限,可以做什么
  }
}
 }

总结

以上所述是小编给大家介绍的JS中回调函数及用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript DOM 学习第三章 内容表格
Feb 19 Javascript
Javascript 多浏览器兼容总结(实战经验)
Oct 30 Javascript
jquery处理页面弹出层查询数据等待操作实例
Mar 25 Javascript
js时间戳转为日期格式的方法
Dec 28 Javascript
图解Javascript——作用域、作用域链、闭包
Mar 21 Javascript
详解vue-cli + webpack 多页面实例应用
Apr 25 Javascript
javascript中mouseenter与mouseover的异同
Jun 06 Javascript
JavaScript全屏和退出全屏事件总结(附代码)
Aug 17 Javascript
Angular中的ng-template及angular 使用ngTemplateOutlet 指令的方法
Aug 08 Javascript
Vue.js组件高级特性实例详解
Dec 24 Javascript
Vue基础配置讲解
Nov 29 Javascript
文章或博客自动生成章节目录索引(支持三级)的实现代码
May 10 Javascript
详解使用mpvue开发github小程序总结
Jul 25 #Javascript
详解mpvue开发小程序小总结
Jul 25 #Javascript
Bootstrap table表格初始化表格数据的方法
Jul 25 #Javascript
JS实现用特殊符号替换字符串的中间部分区域的实例代码
Jul 24 #Javascript
微信小程序实现图片上传放大预览删除代码
Jun 28 #Javascript
vue实现底部菜单功能
Jul 24 #Javascript
vue 下列表侧滑操作实例代码详解
Jul 24 #Javascript
You might like
Laravel 5框架学习之环境与配置
2015/04/08 PHP
PHP的openssl加密扩展使用小结(推荐)
2016/07/18 PHP
php实现微信模板消息推送
2018/03/30 PHP
微信公众号实现扫码获取微信用户信息(网页授权)
2019/04/09 PHP
js GridView 实现自动计算操作代码
2009/03/25 Javascript
js实现的日期操作类DateTime函数代码
2010/03/16 Javascript
ymPrompt的doHandler方法来实现获取子窗口返回值的方法
2010/06/25 Javascript
基于jquery实现漂亮的动态信息提示效果
2011/08/02 Javascript
js 三级关联菜单效果实例
2013/08/13 Javascript
jquery中常用的SET和GET$(”#msg”).html循环介绍
2013/10/09 Javascript
javascript中的事件代理初探
2014/03/08 Javascript
JavaScript极简入门教程(二):对象和函数
2014/10/25 Javascript
JS实现DIV容器赋值的方法
2015/12/14 Javascript
angularjs中$http异步上传Excel文件方法
2018/02/23 Javascript
jquery实现的简单轮播图功能【适合新手】
2018/08/17 jQuery
vue vue-Router默认hash模式修改为history需要做的修改详解
2018/09/13 Javascript
PM2自动部署代码步骤流程总结
2018/12/10 Javascript
如何解决js函数防抖、节流出现的问题
2019/06/17 Javascript
JavaScript实现猜数字游戏
2020/05/20 Javascript
vue 公共列表选择组件,引用Vant-UI的样式方式
2020/11/02 Javascript
跟老齐学Python之坑爹的字符编码
2014/09/28 Python
Python中使用tarfile压缩、解压tar归档文件示例
2015/04/05 Python
Python 含参构造函数实例详解
2017/05/25 Python
python迭代dict的key和value的方法
2018/07/06 Python
python学习——内置函数、数据结构、标准库的技巧(推荐)
2019/04/18 Python
pandas基于时间序列的固定时间间隔求均值的方法
2019/07/04 Python
python获取全国城市pm2.5、臭氧等空气质量过程解析
2019/10/12 Python
Python 爬取必应壁纸的实例讲解
2020/02/24 Python
python/golang实现循环链表的示例代码
2020/09/14 Python
美国一家著名的手表在线折扣网站:Discount Watch Store
2020/02/24 全球购物
限量版运动鞋和街头服饰:TheDrop
2020/09/06 全球购物
消防安全宣传标语
2014/06/07 职场文书
设计专业自荐信
2014/06/19 职场文书
2014年办公室文秘工作总结
2014/12/09 职场文书
十二生肖观后感
2015/06/12 职场文书
Django Paginator分页器的使用示例
2021/06/23 Python