在javascript OOP中,我们经常会这样定义:
function cat() { }
cat.prototype = {
food: "fish",
say: function () {
alert("I love " +
this.food);
}
};
var blackCat =
new cat;
//blackCat.say();
var whiteDog = { food:
"bone" };
blackCat.say.call(whiteDog);
console.log(whiteDog);
但是如果我们有一个对象whiteDog = {food:"bone"},我们不想对它重新定义say方法,那么我们可以通过call或apply用blackCat的say方法:blackCat.say.call(whiteDog);
所以,可以看出call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。
本文介绍如何在JavaScript中利用call与apply方法实现不同对象间方法的借用,以达到动态改变this指向的目的。通过具体示例展示了如何利用这两种方法解决实际编程中遇到的问题。
4836

被折叠的 条评论
为什么被折叠?



