快速理解js中的callapply

40次阅读

共计 869 个字符,预计需要花费 3 分钟才能阅读完成。

今天被小伙伴问到 js 中的 callapply 的区别和用途,解释了一番后,想到之前在逼乎上看到更清楚的解释

第一位生动形象的回答

本身不难理解,看下 MDN 就知道了,但是不常用,遇到了,还要脑回路回转下。或者时间长了,还是要确定下去看下文档,为了方便记忆:

猫吃鱼,狗吃肉,奥特曼打小怪兽。有天狗想吃鱼了

猫. 吃鱼.call(狗,鱼)

狗就吃到鱼了

猫成精了,想打怪兽

奥特曼. 打小怪兽.call(猫,小怪兽)

或者更直接的 马云. 赚钱.call(我)
第二位的回答

还有一位杨志大佬解释的更清楚

我们要先明白存在 call 和 apply 的原因,才能记得牢一点:

在 javascript OOP 中,我们经常会这样定义:

function cat(){}

cat.prototype={
    food:"fish",
    say: function(){alert("I love"+this.food);
    }
}
var blackCat = new cat;
blackCat.say();

但是如果我们有一个对象 whiteDog = {food:"bone"}, 我们不想对它重新定义 say 方法,

那么我们可以通过 call 或 apply 用 blackCat 的 say 方法:blackCat.say.call(whiteDog);

所以,可以看出 call 和 apply 是为了 动态改变 this而出现的,当一个 object 没有某个方法,但是其他的有,我们可以 借助 call 或 apply 用其它对象 的方法来操作。

用的比较多的,通过 document.getElementsByTagName 选择的 dom 节点是一种类似 array 的 array。

它不能应用 Array 下的 push,pop 等方法。我们可以通过:

var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*"));

这样 domNodes 就可以应用 Array 下的所有方法了。

其他的就不提了,讲多了反而迷惑。

call 和 apply 的用法都是一样的,只是传参不同,apply 是数组,call 是参数

大家这回记住了吗?

正文完
 0