源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

javascript中apply和call方法的作用及区别说明

  • 时间:2022-04-02 16:09 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:javascript中apply和call方法的作用及区别说明
[b]一、call和apply的说明[/b] 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、不同点:方法传递的参数不同。 [b]二、实例代码 [/b]
[u]复制代码[/u] 代码如下:
<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>
[b]三、代码解释(即说明apply和call作用)[/b] 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的当前作用对象。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部