js回调函数原理与用法案例分析


Posted in Javascript onMarch 04, 2020

本文实例讲述了js回调函数原理与用法。分享给大家供大家参考,具体如下:

回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。

函数指针是指向函数的指针变量。 因此“函数指针”本身首先应是指针变量,只不过该指针变量指向函数。

函数指针有两个用途:调用函数和做函数的参数。

作用:

js代码会至上而下一条线执行下去,但是有时候我们需要等到一个操作结束之后再进行下一个操作,这时候就需要用到回调函数。

基本案例:

<script language="javascript" type="text/javascript">
function doSomething(callback) {
  // 调用回调函数
  callback('我', '网名', '叶落森');
}
function foo(a, b, c) {
  //这是回调函数
  alert(a + " " + b + " " + c);
}
doSomething(foo);
</script>

项目中的案例:

vue项目中假设store中this指向没指向到vue,那么就可以用回调函数来实现它的iview的this.$Message效果。(当然这是很傻的。this指向没指向到vue,我们可以把vue引进store后,再new Vue()就行。import Vue from 'vue'      var vuethis=new Vue())

a.js

import {mapActions, mapGetters} from 'vuex';
export default {
  name: 'role',
  data () {
    return {

    };
  },
  computed: {},
  methods: {
    ...mapActions(['getRoleData', 'getPowerData']),
      callbackFn(type,content){//这是回调函数
        if(type){
          this.$Message.success(content)
        }else{
          this.$Message.error({
            content: content,
            duration: 5
          })
        }
      },
      initRoleId () {
         this.getRoleData({path:'http://www.baidu.com/',callbackFn:this.callbackFn});
      }
  },
  mounted(){
    this.initRoleId();
  }
};

store中的js

actions: {
    getRoleData ({commit}, {path,callbackFn}) {
      axios.get(path + 'roles', {params: {pageSize: 500}}).then(res => {
        if(res.data.retCode=="200"){
          commit('ROLE_DATA', {roleData: res.data.data.records});
        }else{
          callbackFn(0,res.data.message)//调用回调函数
        }
      });
    },
}

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

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

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

Javascript 相关文章推荐
JS实现随机化快速排序的实例代码
Aug 01 Javascript
jquery实现鼠标滑过显示提示框的方法
Feb 05 Javascript
jQuery图片特效插件Revealing实现拉伸放大
Apr 22 Javascript
JavaScript中字符串(string)转json的2种方法
Jun 25 Javascript
AngularJS ng-change 指令的详解及简单实例
Jul 30 Javascript
微信小程序 Page()函数详解
Oct 17 Javascript
JavaScript判断浏览器及其版本信息
Jan 20 Javascript
jQuery 禁止表单用户名、密码自动填充功能
Oct 30 jQuery
jQuery中$原理实例分析
Aug 13 jQuery
关于JavaScript 数组你应该知道的事情(推荐)
Apr 10 Javascript
vue动态循环出的多个select出现过的变为disabled(实例代码)
Nov 10 Javascript
微信小程序使用前置摄像头拍照
Oct 22 Javascript
在pycharm中开发vue的方法步骤
Mar 04 #Javascript
Vue+Vuex实现自动登录的知识点详解
Mar 04 #Javascript
vuex入门最详细整理
Mar 04 #Javascript
JavaScript 严格模式(use strict)用法实例分析
Mar 04 #Javascript
vue 自定义组件的写法与用法详解
Mar 04 #Javascript
js找出5个数中最大的一个数和倒数第二大的数实现方法示例小结
Mar 04 #Javascript
vue请求数据的三种方式
Mar 04 #Javascript
You might like
js location.replace与location.reload的区别
2010/09/08 Javascript
基于jquery的二级联动菜单实现代码
2011/04/25 Javascript
基于js disabled=&quot;false&quot;不起作用的解决办法
2013/06/26 Javascript
jQuery javaScript捕获回车事件(示例代码)
2013/11/07 Javascript
js实现页面跳转重定向的几种方式
2014/05/29 Javascript
NodeJS中的MongoDB快速入门详细教程
2016/11/11 NodeJs
ionic2自定义cordova插件开发以及使用(Android)
2017/06/19 Javascript
详解在vue-cli项目中使用mockjs(请求数据删除数据)
2017/10/23 Javascript
关于Vue在ie10下空白页的debug小结
2018/05/02 Javascript
countup.js实现数字动态叠加效果
2019/10/17 Javascript
vue excel上传预览和table内容下载到excel文件中
2019/12/10 Javascript
微信小程序实现可长按移动控件
2020/11/01 Javascript
浅析JavaScript中的事件委托机制跟深浅拷贝
2021/01/20 Javascript
[02:22]2018DOTA2亚洲邀请赛VG赛前采访
2018/04/03 DOTA
[59:30]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.22
2019/09/05 DOTA
python 图片验证码代码分享
2012/07/04 Python
使用python的chardet库获得文件编码并修改编码
2014/01/22 Python
python杀死一个线程的方法
2015/09/06 Python
Python随机生成带特殊字符的密码
2016/03/02 Python
Python中遇到的小问题及解决方法汇总
2017/01/11 Python
浅谈Python 的枚举 Enum
2017/06/12 Python
详谈Python高阶函数与函数装饰器(推荐)
2017/09/30 Python
python使用turtle绘制分形树
2018/06/22 Python
python redis 删除key脚本的实例
2019/02/19 Python
python threading和multiprocessing模块基本用法实例分析
2019/07/25 Python
Python生成器实现简单&quot;生产者消费者&quot;模型代码实例
2020/03/27 Python
美国时尚在线:Showpo
2017/09/08 全球购物
美国室内和室外装饰花盆购物网站:ePlanters
2019/03/22 全球购物
自主招生自荐信格式
2013/12/03 职场文书
怎么写好自荐书
2014/03/02 职场文书
公司营业员的自我评价
2014/03/04 职场文书
党员自我评议个人对照检查材料
2014/09/16 职场文书
销售督导岗位职责
2015/04/10 职场文书
2015年信息宣传工作总结
2015/05/26 职场文书
2019年浪漫婚礼证婚词
2019/06/27 职场文书
解决Goland 同一个package中函数互相调用的问题
2021/05/06 Golang