关于JS中apply方法的基本理解

最近研究OpenLayers源码时,发现其中使用了比较多的apply方法,对其也是很不明白。于是上网经过多方面了解以及自己细细体会后,终于算是基本明白是其干什么的了,这里分享下。
apply方法的造型是这样的,Function.apply(obj,args) 能接收两个参数:
obj:这个对象将代替Function类里this对象
args:这个是数组,它将作为参数传递。
按网上大牛的解释是apply:劫持另外一个对象(a)的方法,继承a的属性.
为了进一步理解,我自己做了下小例子,如下:

(function () {
    /*定义一个方法 rockMeber 有两个属性 name、location*/
    var rockMeber = function (name, loction) {
        this.name = name;
        this.loction = loction;
    };

    /*再定义一个方法 rockTeam 会调用rockMeber*/
    var rockTeam = function (name, loction, teamName) {
         /*
         *可以这么理解:this为当前的rockTeam,arguments为参数列表数组形式。
         *执行apply方法时,rockMeber中的this就是rockTeam,
         *所以rockTeam也会有name、location属性并进行赋值。
         *同时会将this(rockTeam)返回。所以我们进行输出时,rockteam就会有相应的属性值。
         *也可以这么理解为:rockMeber将属性创建到了rockTeam对象里面。
         */
        rockMeber.apply(this, arguments);
        
        this.teamName = teamName;
    };

    $('#havetry').click(function () {
        var rockteam = new rockTeam('石头', '吉他手', 'mayday');
        $('#result').text('名字:'   rockteam.name   '   '   '职位:'   rockteam.loction   '   '   '乐队:'   rockteam.teamName);
    });

});

  代码中的注释写的也比较清楚,就不多说了,这就是我对apply的理解。

 

posted @ 2015-06-23 14:16  拽不过现实  阅读(628)  评论(0编辑  收藏  举报