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

JS复习之Call和Apply

时间:2017-11-08 22:15:31      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:构造   bsp   join   div   出现   lte   cat   you   另一个   

  文章见于知乎:https://www.zhihu.com/question/20289071

  如果知道call和apply的创造原因,应该就能很方便的理解它们了。

  如果正常来说,创造这样一个构造函数与实例的话,是能直接使用的

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

 

  但如果让另一个实例使用say方法,那么就得让它拥有,但明显重写是不太智能的,所以就出现了call和apply

  

       var wilteDog={
                food:‘bone‘
            }
            blackCat.say.call(wilteDog);

  这样就可以让只有food属性的wilteDog对象使用wilte的say方法

  相关实例:

  

       function arr(){
                 var arg = arguments;
                 console.log([].join.call(arg,‘B‘));
            }
            arr(‘1‘,‘3‘)

 

  

JS复习之Call和Apply

标签:构造   bsp   join   div   出现   lte   cat   you   另一个   

原文地址:http://www.cnblogs.com/MyZsy/p/7806253.html

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