首页 > 移动平台 > 详细

JS复习之Call和Apply

时间:2017-11-08 21:50:11      阅读:250      评论:0      收藏:0      [点我收藏+]

  文章见于知乎: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

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!