zoukankan      html  css  js  c++  java
  • 简单理解js回调函数

    前言

    其实回调函数简单通俗点就是当有a和b两个函数,当a作为参数传给b,并在b中执行,这时a就是一个回调(callback)函数,如果a是一个匿名函数,则为匿名回调函数那下面们来通过一个实例来具体解释下Javascript回调函数怎么使用。

    实例

    在很久很久以前,有一个人。

     var person;

    他是个人,也就是一个对象。

    person= {}; // 在JavaScript中,花括号就代表是一个对象

    他有个名字叫小明。

    person.name = '小明';

    看一下是不是真的叫小明。

    alert(person.name);

    嗯,有一天,小明捡到了10块钱。

    person.money = '10块钱';

    有了钱就要花,于是他打算把10块钱用掉。

    小明有一个花钱的方法 spendMoney ()

    person.spendMoney =function(){  alert(this.name +"用 "+this.money +" 块钱买了漫画书!"); 

    运行:

    person.spendMoney();
     

    弹出提示:小明用10块钱买了漫画书。

    好了,问题来了,小明花钱就非得买漫画书吗,肯定不是。

    事实情况应该是,这钱怎么办,还是由他自己说了算。因为钱在小明的口袋里。

    所以,就可以用回调函数了。

    回调函数本身就是一个数据类型。

    在javaScript中,函数的地位和java中的Stringintboolean等等都是一样的,都可以看成是一个数据类型。

    既然是数据类型,当然可以当成参数传递。

    于是就应该这样:

    person.spendMoney =function(doSomeThing){  doSomeThing();
     

    打了个括号就是执行函数的意思。

    没打括号的函数,就是和Stringint一样的玩意儿。

    是一个数据类型。

    一样的。

    JAVA里面会这么写:

    String str ="HelloWorld!";

    在JavaScript中,函数也是一样的。

    var say =function(){
     
       alert('HelloWorld');
     
    }

    这时候的say就是一个数据类型。

    因为没有打括号,打了括号他才会执行!

    小明用十块钱做什么,他自己说了算。

    person.spendMoney(function(){});

    这样就是把函数传进去了。

    把函数传入spendMoney方法的目的就是让函数在里面执行的。

    person.spendMoney =function(doSomeThing){  doSomeThing(); 

    所以:

    里面就打了括号,代表要执行这个函数。

    具体做什么,自己决定。

    person.spendMoney(function(){  alert('还是把钱存起来吧!'); })

    总结

    就是可以将函数作为一个参数,传入一个方法内,并且能够在该方法中执行这个函数,这也就是js特有的回调函数的魔力。

    以上就是关于Javascript回调函数用法的全部内容,希望对大家的学习和工作能有所帮助。如果有疑问可以留言讨论。

  • 相关阅读:
    网络IO之阻塞、非阻塞、同步、异步总结
    C语言栈与调用惯例
    多个文件目录下Makefile的写法
    利用 mount 指令解决 Read-only file system的问题
    error while loading shared libraries: xxx.so.x" 错误的原因和解决办法
    Centos6.4下安装protobuf及简单使用
    Centos下修改启动项和网络配置
    Centos下配置单元测试工具gtest
    Centos配置为驱动程序开发环境
    Centos安装gcc及g++
  • 原文地址:https://www.cnblogs.com/hpx2020/p/8819084.html
Copyright © 2011-2022 走看看