全面解析JavaScript中apply和call以及bind(推荐)


Posted in Javascript onJune 15, 2016

函数调用方法

在谈论JavaScript中apply、call和bind这三兄弟之前,我想先说下,函数的调用方式有哪些:

•作为函数

•作为方法

•作为构造函数

•通过它们的call()和apply()方法间接调用

前面的三种调用方法,我们都知道且不在这篇文章的讨论范围内,就不说了。

下面我们来说说这第四种调用方法

通过call()和apply()间接调用

其实,我们可以将这两个函数看做是某个对象的方法,通过调用方法的方式来间接调用函数:

function f(){}
f.call(o);
f.apply(o);

call()和apply()的第一个参数是要调用函数的母对象,它是调用上下文,在函数体内通过this来获得对它的引用。

那么他们是一样的,还是有区别的,还有bind方法呢?君莫急,下面详细的解析他们三者的区别和联系。

call()

call()方法给调用它的方法指定特定的this指针(习惯用语,不要和我纠结它的正确性)和参数。例如有这么一个函数:

var fn = function (arg1, arg2) {
console.log(this, arg1, arg2); 
}

我来调用它:

fn.call(null, 'Skylor', 'min'); //1
fn.call(undefined, 'Skylor', 'min'); //2
var fx = function() {}
fn.call(fx, 'Skylor', 'min'); //3

这三个call方法的返回值是什么呢?不废话,请看:

1. null "Skylor" "min"
2. undefined "Skylor" "min"
3. fx "Skylor" "min"

真的是这样吗,机智的你,去浏览器控制台小试了一下,我去,你这坑货,不是这样的:

chrome
1. Window "Skylor" "min"
2. Window "Skylor" "min"
3. fx "Skylor" "min"

好吧,你机智。但这已经很好的说明了call方法了。(window很高级,微软偷笑中...)

我们注意到call方法,第一个参数是指定this指针,后面每个参数指定需要的参数,注意我用的是“每个”,这意味着你需要几个参数就要想调用函数那样,一个个参数写进去。

apply()

apply()是call()的兄弟啊,其他地方长的都一样,都是男的,就一个地方不一样。先看例子:

fn.apply(null, ['Skylor', 'min']); //1
fn.apply(fx, ['Skylor', 'min']); //2

哥们,你是不是写错了,多了个中括号啊。不,不,不,这就是他和call长的不一样的地方,它的第二个参数是个需要的参数Array。

bind()

bind()嘛,他们三个不是仨兄弟嘛,,这个我懂,blabla....不不不,它是和apply、call结拜的兄弟,不是亲兄弟。

当然,bind方法也是允许你指定this指针,但是它不是调用函数,而是返回一个(或者说是拷贝)调用它的函数的函数,并给这个函数指定特定的this指针和参数。惯例,例子说明一切:

var fnbound = fn.bind(null, 'Skylor', 'min');

这时,fnbound是一个函数,一个this指向null,参数为['Skylor', 'min']的另一个函数。调用之:

fnbound();

结果:

null, 'Skylor', 'min'

不要和我纠结Window的事了。。。。。

bind和其他两个兄弟不一样的地方,是,它不是调用函数,而是返回一个新的函数,同样,它也是指定this指针和参数的,指定参数的方式和call一样,是一个一个来的。

最后来一个例子呗:

var shoppingCart = (function(){
var _calculatePrice = function () {
return this.price * this.amount;
};
return {
calculatePrice : _calculatePrice
}
})();
var goods = {
name : ‘hammer',
price: 199,
amount : 2
};
shoppingCart.calculatePrice.call(goods);

到此结束。!

以上所述是小编给大家介绍的JavaScript中apply和call以及bind(推荐)的全部内容,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 动态创建VML的方法
Oct 14 Javascript
23个超流行的jQuery相册插件整理分享
Apr 25 Javascript
jquery调用asp.net 页面后台的实现代码
Apr 27 Javascript
JS+CSS实现电子商务网站导航模板效果代码
Sep 10 Javascript
JavaScript职责链模式概述
Sep 17 Javascript
js判断手机系统是android还是ios
Mar 07 Javascript
JavaScript之filter_动力节点Java学院整理
Jun 28 Javascript
基于JavaScript实现淘宝商品广告效果
Aug 10 Javascript
vue.js中proxyTable 转发请求的实现方法
Sep 20 Javascript
详解在不使用ssr的情况下解决Vue单页面SEO问题
Nov 08 Javascript
JavaScript实现的级联算法示例【省市二级联动功能】
Dec 25 Javascript
Layui动态生成select下拉选择框不显示的解决方法
Sep 24 Javascript
JavaScript仿flash遮罩动画效果
Jun 15 #Javascript
jquery中的常见问题及快速解决方法小结
Jun 14 #Javascript
使用递归遍历对象获得value值的实现方法
Jun 14 #Javascript
浅谈js里面的InttoStr和StrtoInt
Jun 14 #Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
Jun 14 #Javascript
JS递归遍历对象获得Value值方法技巧
Jun 14 #Javascript
全面解析JavaScript中的valueOf与toString方法(推荐)
Jun 14 #Javascript
You might like
用文本文件制作留言板提示(下)
2006/10/09 PHP
php反弹shell实现代码
2009/04/22 PHP
PHP实现清除wordpress里恶意代码
2015/10/21 PHP
php添加数据到xml文件的简单例子
2016/09/08 PHP
PHP unlink与rmdir删除目录及目录下所有文件实例代码
2018/02/07 PHP
PHP设计模式之PHP迭代器模式讲解
2019/03/22 PHP
js玩一玩WSH吧
2007/02/23 Javascript
使用jQuery清空file文件域的解决方案
2013/04/12 Javascript
JS模拟自动点击的简单实例
2013/08/08 Javascript
JS匀速运动演示示例代码
2013/11/26 Javascript
js实现带关闭按钮始终显示在网页最底部工具条的方法
2015/03/02 Javascript
js实现仿百度汽车频道选择汽车图片展示实例
2015/05/06 Javascript
jquery预加载图片的方法
2015/05/27 Javascript
JS获取屏幕高度的简单实现代码
2016/05/24 Javascript
浅谈jQuery中ajaxPrefilter的应用
2016/08/01 Javascript
每个程序员都需要学习 JavaScript 的7个理由小结
2016/09/03 Javascript
详解XMLHttpRequest(一)同步请求和异步请求
2016/09/14 Javascript
判断数组的最佳方法(推荐)
2016/10/11 Javascript
Vue resource三种请求格式和万能测试地址
2018/09/26 Javascript
Vue.use()在new Vue() 之前使用的原因浅析
2019/08/26 Javascript
mpvue实现左侧导航与右侧内容的联动
2019/10/21 Javascript
微信小程序自定义组件components(代码详解)
2019/10/21 Javascript
原生javascript如何实现共享onload事件
2020/07/03 Javascript
JS代码简洁方式之函数方法详解
2020/07/28 Javascript
[52:08]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第一局
2016/03/05 DOTA
实例解析Python中的__new__特殊方法
2016/06/02 Python
利用Python中SocketServer 实现客户端与服务器间非阻塞通信
2016/12/15 Python
python issubclass 和 isinstance函数
2019/07/25 Python
深入理解Python变量的数据类型和存储
2021/02/01 Python
材料化学应届生求职信
2013/10/09 职场文书
机械设计及其自动化专业推荐信
2013/10/31 职场文书
营销与策划专业毕业生求职信
2013/11/01 职场文书
理工科学生的自我评价
2013/12/15 职场文书
2014年综治宣传月活动总结
2014/04/28 职场文书
霸气队列口号
2014/06/18 职场文书
士兵突击观后感
2015/06/16 职场文书