码迷,mamicode.com
首页 > 移动开发 > 详细

超容易理解的call()、apply()、bind()的区别

时间:2019-06-15 15:37:05      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:blog   function   特殊情况   例子   返回   dog   图片   mic   调用   

call()、apply()、bind()是用来改变this的指向的。

一 举个例子

一个叫喵喵的猫喜欢吃鱼,一个叫汪汪的小狗喜欢啃骨头,用代码实现如下:

var cat = {
name:"喵喵",
eatFish:function(param1,param2){
console.log("吃鱼");
console.log("this的指向=>");
console.log(this);
console.log(param1,param2);
}
}

var dog = {
name:"汪汪",
eatBone:function(param1,param2){
console.log("啃骨头");
console.log("this的指向=>");
console.log(this);
console.log(param1,param2)
}
}
有一天,小狗汪汪和喵喵共进午餐的时候,汪汪说自己想尝尝小鱼干的味道,但是因为有刺,喵喵就想了个办法,说自己先吃,完了喂给汪汪。

//第一种,用call方法
cat.eatFish.call(dog,"旺财-13岁","call");
//第二种,用apply方法,参数不一样
cat.eatFish.apply(dog,["旺财-13岁","apply"]);

技术图片

 


这样,汪汪就吃到了美味的鱼干。可是汪汪每吨都想来点小鱼干,喵喵还要工作去捉老鼠,所以它们又想了一个办法,喵喵把吃鱼的方法教给汪汪。这样,每次汪汪就可以自己吃小鱼干了。

var eatFishFun = cat.eatFish.bind(dog,"旺财-13岁","bind"); //返回的是方法

eatFishFun();

技术图片

 

bind()方法在这里再多说一下,bind的时候传的参数会预先传给返回的方法,调用方法时就不用再传参数了。

撇开上面的例子,看看一个特殊情况:

如果call()和apply()的第一个参数是null或者undefined,那么this的指向就是全局变量,在浏览器里就是window对象。

 技术图片

 

以上,就是三个方法的用法和区别,如果有任何问题,欢迎高质量的交流。
---------------------
作者:Lin_Dan_Dan
来源:CSDN
原文:https://blog.csdn.net/u010176097/article/details/80348447
版权声明:本文为博主原创文章,转载请附上博文链接!

超容易理解的call()、apply()、bind()的区别

标签:blog   function   特殊情况   例子   返回   dog   图片   mic   调用   

原文地址:https://www.cnblogs.com/sugartang/p/11027480.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!