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

Js 中apply 与 call

时间:2015-07-10 18:18:14      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:

最近看JS 总是遇到 对象的替换,不是很了解 JS中call 与apply的用法,在这里 轻轻瞄一下,只是自己理解下其用法:

apply  定义应用某一对象的一个方法,用另一个对象替换当前对象。 apply([thisObj[,argArray]])

call   定义调用一个对象的一个方法,以另一个对象替换当前对象。 call([thisObj[,arg1[, arg2[,   [,.argN]]]]])

  从上面可以看出 其实他们的用法几乎一样,唯一的区别就是,调用时,apply传入的参数形式是数组的形式,而call则没有这个需求;也就是

当你的参数是明确知道数量时,用 call,而不确定的时候,用 apply,然后把参数 push 进数组传递进去;

具体的用法,用一个实例来看一下,如下:

 

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

 

 输出的效果如下图所示:

技术分享

技术分享

 从上面就可以看出:

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

我们有一个对象dog= {food:"bone"},我们不想对它重新定义say方法,那么我们可以通过call或apply用blackCat的say方法:blackCat.say.call(whiteDog);

有一种OOP中继承的思想在里面。

    以上只是在网上看到大神们的讲解,比较容易理解的text,以此成文,在此和大家共勉,希望大家提供more 的理解。。。。。。

 

Js 中apply 与 call

标签:

原文地址:http://www.cnblogs.com/jsdabai/p/4636286.html

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