随笔 - 312  文章 - 0  评论 - 2  阅读 - 11万

JS:回调函数1

回调函数 (callback)

我理解的回调函数就是,将一个函数a作为参数,传递进另一个函数b运行,那么a就是那个回调函数。

例:

复制代码
        function fn(arg) {
            var a = 1;
            arg(a);//调用fm,并把a当作参数传入fm
        }
        fn(function fm() {
            console.log("this is fm");
        });
        //还可以换成另一种写法就是直接写回调函数的函数名:
        // fn(fm);
        // function fm() {
        //     console.log("this is fm");
        // }
复制代码

打印结果:

this is fm

 

理解:

如果直接在 console.log("this is fm") 中写入‘a’,打印会报错,这说明fm不在fn的作用域内,仅仅是被fn调用

 

例2:

        function fn(arg) {
            var a = 1;
            console.log(arg);
            arg();
        }
        fn(function fm() {console.log("this is fm");});

打印结果:

ƒ fm() {
console.log("this is fm");
}
this is fm

 

理解:

我们可以看到打印arg参数是fm整个函数被传入还未被调用。当arg()时,才是调用了fm。

 

例3:

        function fn(url,callback){
            var output = url;
            callback(output);
        }
        fn('http://www.baidu.com',function fm(data){console.log(data);})

打印结果:

http://www.baidu.com

 

理解:

fn调用时,传入的参数是一个字符串和一个函数;在fn内部又声明了一个变量被赋值为传入的字符串,然后再将那个变量传入回调函数调用的代码中,运行输出。

 

posted on   香香鲲  阅读(48)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示