<strong>区分apply,call就一句话:</strong> `foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments)==this.foo(arg1, arg2, arg3)` <font size=1>call, apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例,也就是每个方法都有call, apply属性.既然作为方法的属性,那它们的使用就当然是针对方法的了.这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同.</font> <strong>不同点:方法传递的参数不同</strong> ``` <script type="text/javascript"> /* * apply方法: * 语法:apply(thisObj,[argArray]) * 定义:应用某一对象的一个方法,用另一个对象替换当前对象。 */ //定义一个人类 function Person(name,age){ this.name = name; this.age = age; } //定义一个学生类 function Student(name,age,grade){ Person.apply(this,arguments); //或者 Person.call(this,name,age) this.grade = grade; } var student = new Student("dqf","20","一年级"); console.info("name:"+student.name+"\n"+"age:"+student.age+"\n"+"grade:"+student.grade); ``` <font color=red>结果如下:<font> ![这里写图片描述](https://img-blog.csdn.net/20160628081004815) ``` var b = new B(); //给对象a动态指派b的setMessage方法,注意,a本身是没有这方法的! //a的消息是setMessage()的参数列表 b.setMessage.call(a, "a的消息"); //下面将显示"a的消息" alert(a.getMessage()); //给对象b动态指派a的getMessage方法,注意,b本身也是没有这方法的! /* b.setMessage.call(a,"a的消息"); 其实就相当于a.setMessage("a"的消息) call, apply作用就是借用别人的方法来调用,就像调用自己的一样. */ ``` <strong>call, apply方法区别是,从第二个参数起, call方法参数将依次传递给借用的方法作参数, 而apply直接将这些参数放到一个数组中再传递, 最后借用方法的参数列表是一样的.</strong> 部分资料来源: > http://www.cnblogs.com/fighting_cp/archive/2010/09/20/1831844.html
js call() apply()
最新推荐文章于 2024-05-07 14:50:37 发布