js中的回调函数(深入使用)

前言

使用过很多js插件的同学就知道,回调函数在插件的使用中贡献特别大,极大的简化和便利了插件的使用。

例如jquery的ajax就有这样的回调:

$.ajax({
    url: '...',
    data: {value: '123'},
    success: function(res){
        console.log(res); // 可调用参数
        console.log(this.data); // this指向当前对象而不是window
    }
})

但是在封装自己的函数时,应该怎么做回调呢?

使用方法

参考文章:https://www.cnblogs.com/gaosheng-221/p/6045483.html

 核心:使用call或apply来向回调函数传递正确的this和参数

call接收的第一个参数为被用来在函数内部当做this的对象,传递给函数的参数被挨个传递(当然使用逗号分开)。

Apply函数的第一个参数也是在函数内部作为this的对象,然而最后一个参数确是传递给函数的值的数组。

如,我们封装一个方法:

function afunction(options){
    var returnParam1 = options.param + 1;
    var returnParam2 = options.param + 2;
    if(typeof options.callback == 'function'){
        options.callback.apply(options, [returnParam1, returnParam2]);
    }
}


 调用这个方法:

afunction({
    param: 100,
    callback: function(param1, param2){
        console.log(param1); //101
        console.log(param2); //102
        console.log(this.param); // 100
    }
});

效果如下:

很容易看出,.apply可以将调用函数,并设置其this变量和参数。

其他

如果不需要指定this,可以不使用apply,直接这样写,也可以传递参数。

callback(param1, param2);

 

转载于:https://www.cnblogs.com/mankii/p/10487712.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值