时间:2021-05-25
函数调用方法
在谈论JavaScript中apply、call和bind这三兄弟之前,我想先说下,函数的调用方式有哪些:
•作为函数
•作为方法
•作为构造函数
•通过它们的call()和apply()方法间接调用
前面的三种调用方法,我们都知道且不在这篇文章的讨论范围内,就不说了。
下面我们来说说这第四种调用方法
通过call()和apply()间接调用
其实,我们可以将这两个函数看做是某个对象的方法,通过调用方法的方式来间接调用函数:
call()和apply()的第一个参数是要调用函数的母对象,它是调用上下文,在函数体内通过this来获得对它的引用。
那么他们是一样的,还是有区别的,还有bind方法呢?君莫急,下面详细的解析他们三者的区别和联系。
call()
call()方法给调用它的方法指定特定的this指针(习惯用语,不要和我纠结它的正确性)和参数。例如有这么一个函数:
我来调用它:
这三个call方法的返回值是什么呢?不废话,请看:
真的是这样吗,机智的你,去浏览器控制台小试了一下,我去,你这坑货,不是这样的:
好吧,你机智。但这已经很好的说明了call方法了。(window很高级,微软偷笑中...)
我们注意到call方法,第一个参数是指定this指针,后面每个参数指定需要的参数,注意我用的是“每个”,这意味着你需要几个参数就要想调用函数那样,一个个参数写进去。
apply()
apply()是call()的兄弟啊,其他地方长的都一样,都是男的,就一个地方不一样。先看例子:
哥们,你是不是写错了,多了个中括号啊。不,不,不,这就是他和call长的不一样的地方,它的第二个参数是个需要的参数Array。
bind()
bind()嘛,他们三个不是仨兄弟嘛,,这个我懂,blabla....不不不,它是和apply、call结拜的兄弟,不是亲兄弟。
当然,bind方法也是允许你指定this指针,但是它不是调用函数,而是返回一个(或者说是拷贝)调用它的函数的函数,并给这个函数指定特定的this指针和参数。惯例,例子说明一切:
这时,fnbound是一个函数,一个this指向null,参数为['Skylor', 'min']的另一个函数。调用之:
fnbound();
结果:
null, 'Skylor', 'min'
不要和我纠结Window的事了。。。。。
bind和其他两个兄弟不一样的地方,是,它不是调用函数,而是返回一个新的函数,同样,它也是指定this指针和参数的,指定参数的方式和call一样,是一个一个来的。
最后来一个例子呗:
到此结束。!
以上所述是小编给大家介绍的JavaScript中apply和call以及bind(推荐)的全部内容,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在Javascript中,Function是一种对象。Function对象中的this指向决定于函数被调用的方式。使用apply,call与bind均可以改变函
JavaScript的this和Java等面向对象语言中的this大不一样,bind()、call()和apply()函数更是将this的灵活度进一步延伸。为了
本文实例讲述了javascript中call,apply,callee,caller用法。分享给大家供大家参考,具体如下:实践一:call,apply用来让一个
一、call和apply的说明1、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Fu
本文实例讲述了JS中call()和apply()的功能及用法。分享给大家供大家参考,具体如下:1.call()和apply()的作用首先引出问题:用call()