javascript中apply和call方法的作用及区别说明
一、call和apply的说明
1、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例(就是每个方法)都有call,apply属性。既然作为方法的属性,那它们的使用就当然是针对方法的了,这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同。
2、语法:foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments) == this.foo(arg1, arg2, arg3);
3、相同点:两个方法产生的作用是完全一样的。
4、不同点:方法传递的参数不同。
二、实例代码
<script type="text/javascript">
function A(){
this.flag = 'A';
this.tip = function(){
alert(this.flag);
};
}
function B(){
this.flag = 'B';
}
var a = new A();
var b = new B();
//a.tip.call(b);
a.tip.apply(b);
</script>
三、代码解释(即说明apply和call作用)
1、实例代码定义了两个函数A和B,A中包含flag属性和tip属性(这个属性赋值一个函数),B中有一个flag属性。
2、分别创建A和B的对象a和b。
3、无论是a.tip.call(b);和a.tip.apply(b);运行的结果都是弹出B。
4、从结果中可以看出call和apply都可以让B对象调用A对象的tip方法,并且修改了this的当前作用对象。
- JavaScript中的apply()方法和call()方法使用介绍
- js中继承的几种用法总结(apply,call,prototype)
- 详解js中的apply与call的用法
- JS中改变this指向的方法(call和apply、bind)
- JavaScript中的apply和call函数详解
- js中call与apply的用法小结
- js apply/call/caller/callee/bind使用方法与区别分析
- JS面向对象、prototype、call()、apply()
- JavaScript学习点滴 call、apply的区别
- 详解JS中的this、apply、call、bind(经典面试题)
- 浅谈javascript中call()、apply()、bind()的用法
- JavaScript中apply与call的用法意义及区别说明
- js中apply()和call()的区别与用法实例分析
- 跟我学习javascript的call(),apply(),bind()与回调
- JavaScript中的this,call,apply使用及区别详解
- javascript call和apply方法
- 深入理解JavaScript中的call、apply、bind方法的区别
- 再谈JavaScript中bind、call、apply三个方法的区别与使用方式
最新评论