js中的apply和call API

借用网上的一个例子:

1 fun.call(this,arg1,arg2,arg3)
2
3 fun.apply(this,arguments)
4
5 this.fun(arg1,arg2,arg3)

三种方法等效。

详细内容这篇博客写的很清楚了,我就偷懒转一下了。

转载:http://www.cnblogs.com/fighting_cp/archive/2010/09/20/1831844.html

下面自己在总结一下自己的领悟:

先贴下代码:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <script src="person.js"></script>
 7     <script src="student.js"></script>
 8     <script src="boyStudent.js"></script>
 9 </head>
10 <body>
11 <script src="main.js"></script>
12 </body>
13 </html>
 1 window.meng = window.meng || {};
 2 (function () {
 3
 4     function Person(name, age, gender) {
 5         this._name = name;
 6         this._age = age;
 7         this._gender = gender;
 8     }
 9
10     Person.prototype.showInfo = function () {
11         console.log("个人"+"\n姓名:" + this._name + "\n年龄:"
12             + this._age + "\n性别:" + this._gender);
13     };
14
15     meng.Person = Person;
16 })();
 1 window.meng = window.meng || {};
 2 (function () {
 3
 4     function Student(name,age,gender,num) {
 5         meng.Person.apply(this,arguments);
 6         this._num=num;
 7     }
 8
 9     Student.prototype=new meng.Person();
10     Student.prototype.showInfo=function () {
11         console.log("学生"+"\n姓名:" + this._name + "\n年龄:" +
12             this._age + "\n性别:" + this._gender+"\n学号:"+this._num);
13
14     };
15     meng.Student=Student;
16 })();
window.meng = window.meng || {};
(function () {

    function BoyStudent(name,age,num) {
        meng.Student.call(this,name,age,"female",num);
    }

    BoyStudent.prototype = new meng.Student();
    BoyStudent.prototype.showInfo=function () {
        console.log("男学生"+"\n姓名:" + this._name + "\n年龄:" +
            this._age + "\n性别:" + this._gender+"\n学号:"+this._num);

    };
    meng.BoyStudent=BoyStudent;
})();
 1 (function () {
 2
 3     var per1=new meng.Person("Tom",12,"female");
 4     per1.showInfo();
 5
 6     var stu1=new meng.Student("lilli",13,"female","001");
 7     stu1.showInfo();
 8
 9     var boyStu1=new meng.BoyStudent("David",23,"002");
10     boyStu1.showInfo();
11 })();

输出结果:

好了,下面开始说明:

(这里说明一下,网上有些人说JS没有继承,但是这里我也写了继承。这也就是我对事物的理解问题,我本来专业学过JAVA,所以对继承了解深刻,而上面JS代码的写法和JAVA里的继承是一个概念,我这里就暂且叫他继承了。主要是理解概念,我感觉没必要死扣这个问题,就如有些人还说JS没有JAVA中的类,但是JS中的函数和JAVA的类也是一个差不多的概念,拿类的概念去理解函数的概念,也无可厚非)

开始说代码,先看下各个函数的参数,(这里帖这几个代码的意义也在于此)。

Person参数有三个name、age、gender这是每个人又具备的属性。

Student参数有有四个,多了个学号num的属性,这是学生所特有的。

BoyStudent参数有三个,同学生类中的三个,只是gender参数默认是female。

大体的结构是BoyStudent继承Student  Student继承Person。

BoyStudent继承Student的时候,是三个参数继承四个参数的,顾我用的是call()方法,因为他可以逐个给参数赋值,可以包含不一样的参数。

而Student继承Person的时候,是四个参数继承三个参数的,顾我用的是apply()方法,因为它一下把所有参数搬过来了,简单省事。

当然,call()方法完全可以代替apply()方法,但是能用apply()方法的时候,何必用call()方法逐个去赋值呢。╮(╯▽╰)╭

时间: 2024-10-07 08:12:33

js中的apply和call API的相关文章

js中的apply调用

今天看了阮一锋老师的一篇文章,感觉很明了对闭包的理解,尤其是文章中的apply的介绍 apply()是函数对象的一个方法,它的作用是改变函数的调用对象,它的第一个参数就表示改变后的调用这个函数的对象.因此,this指的就是这第一个参数. var x = 0; function test(){ alert(this.x); } var o={}; o.x = 1; o.m = test; o.m.apply(); //0 apply()的参数为空时,默认调用全局对象.因此,这时的运行结果为0,证明

js中的apply、call、callee、caller的区别

1.apply与call的区别与使用 相同点:2者是函数原型的一个方法,因此调用者都必须是函数,第1个参数都是对象.作用是,用另一个对象替换当前对象,另一对象也即是你传的第一个参数.通常用于改变调用的函数中this的指向.如果不传对象或者传入的为null,那么默认对象就是window. 不同点:第2个参数,为调用的函数的参数,区别是apply要求所有函数的参数放在一个数组中传递. 使用方法: fun.call(thisArg[, arg1[, arg2[, …]]]) fun.apply(thi

js 中的apply

之一------(函数的劫持与对象的复制)关于对象的继承,一般的做法是用复制法: Object.extend 见protpotype.js 的实现方法: Object.extend = function(destination, source) ...{    for (property in source) ...{      destination[property] = source[property];    }    return destination;  } 除此以外,还有一种不太

Js中call apply函数以及this用法

this介绍: C#里this关键字的意义比较确定的.JavaScript的this关键字,随着函数使用场合不同,this的值会发生变化,感觉用法比较混乱,所以,现在是有必要整理一下的时刻了! 总结一个原则:在js里面,this指针代表的是执行当前代码的对象的所有者. 1.和c#类似的纯粹函数调用: function test() { this.x = 1; alert(x); } test();//1 其实这里的this就是全局变量.看下面的例子就能很好的理解这里的this就是全局对象Glob

js中的apply和call

Js apply方法详解 我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里我做如下笔记,希望和大家分享..  如有什么不对的或者说法不明确的地方希望读者多多提一些意见,以便共同提高.. 主要我是要解决一下几个问题: 1.        apply和call的区别在哪里 2.        什么情况下用apply,什么情况下用call 3.        apply的其他

兄台息怒,关于arguments,您的想法和大神是一样一样的----闲聊JS中的apply和call

JavaScript提供了apply和call两种调用方式来确定函数体中this的指向,表现出来的特征就是:对象可以'借用'其他对象的方法.之前的几篇博客回顾了一些Web控件的一些开发方法,我们聊了如何实现一个自定义的组合框,也聊了一个相对复杂一点的地址控件的开发,从上一篇开始,开始聊一些JavaScript语言本身的话题,回顾了闭包和原型继承,今天我们就一起来聊聊apply和call这两种调用方式的前世今生.当然,尽管主题在变,但是基于业务场景来剖析理论知识的写作风格不会变.我们还是从一个生活

JS中的apply,call,bind深入理解

在Javascript中,Function是一种对象.Function对象中的this指向决定于函数被调用的方式.使用apply,call 与 bind 均可以改变函数对象中this的指向,在说区别之前还是先总结一下三者的相似之处: 1.都是用来改变函数的this对象的指向的. 2.第一个参数都是this要指向的对象. 3.都可以利用后续参数传参. call方法: 语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一

详解js中的apply与call的用法

前言 call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改变函数体内部 this 的指向.call 和 apply二者的作用完全一样,只是接受参数的方式不太一样. 方法定义applyFunction.apply(obj,args)方法能接收两个参数: obj:这个对象将代替Function类里this对象 args:这个是数组或类数组,apply方法把这个集合中的元素作为参数传递给被调用的函数. call call方法与apply方法的第

js中的apply 和 call

A.call(B),意思就是把A的上下文(一般是this)借给B用Array.prototype.slice.apply,意思就是把数组对象的slice方法,借给apply第一个参数所指定的对象使用apply第一个参数必须是对象,哪怕是null 所以 Array.prototype.slice.apply(abc) ,就相当于把slice借给abc这个对象(JS里函数也是对象)使用.因为函数是没有slice方法的,直接调用 abc.slice 是要报错的