javascript中apply,call和bind的区别

 我来答
黑马程序员
2017-06-20 · 改变中国IT教育,我们正在行动
黑马程序员
黑马程序员为大学毕业后,有理想、有梦想,想从事IT行业的年轻人改变自己的命运。黑马程序员成就IT黑马
向TA提问
展开全部
1 call(), apply(),bind()都属于Function.prototype的一个内置方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,主要就是围绕这this对象的改变操作。下面已代码逐一展示各自的用法。
2 var a = {
user:"call调用",
fn:function(){
console.log(this.user); //对应的user
}
}
var b = a.fn;
b.call(a);

意思是:call方法,给第一个参数添加要把b添加到哪个环境中,简单来说,this就会指向那个对象。
3 var a = {
user:"applay调用",
fn:function(){
console.log(this.user); // applay调用
}
}
var b = a.fn;
b.apply(a);
apply方法和call方法有些相似,它也可以改变this的指向;不同的是 ,但是不同的是,第二个参数必须是一个数组 如下代码
var a = {
user:"appy调用",
fn:function(e,ee){
console.log(this.user); // applay调用 第二个参数书数组
console.log(e+ee);
}
}
var b = a.fn;
b.apply(a,[10,1]);

4 上bind方法返回的是一个修改过后的函数
var a = {
user:"bind调用",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
b.bind(a);
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式