日期:2014-05-16  浏览次数:20436 次

javascript中apply与call的区别

apply and call 它们的作用都是将函数绑定到另外一个对象上去运行,两者仅在定义参数方式有所区别: apply(thisArg,argArray); call(thisArg[,arg1,arg2…] ]); 即所有函数内部的this指针都会被赋值为thisArg,这可实现将函数作为另外一个对象的方法运行的目的 apply的说明 如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。 如果没有提供 argArray 和 thisArg任何一个参数,那么 Global 对象将被用作 thisArg, 并且无法被传递任何参数。 call的说明 call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisArg指定的新对象。 如果没有提供 thisArg参数,那么 Global 对象被用作 thisArg 相关技巧: 应用call和apply还有一个技巧在里面,就是用call和apply应用另一个函数(类)以后,当前的 函数(类)就具备了另一个函数(类)的方法或者是属性,这也可以称之为“继承”。看下面示例: // 继承的演示 function base() { this.member = " dnnsun_Member"; this.method = function() { window.alert(this.member); } } function extend() { base.call(this); window.alert(member); window.alert(this.method); } 上面的例子可以看出,通过call之后,extend可以继承到base的方法和属性。