zoukankan      html  css  js  c++  java
  • js中的call和apply方法的区别

    一、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的当前作用对象。

  • 相关阅读:
    P1908 逆序对
    P3834 【模板】可持久化线段树 1(主席树)
    BZOJ 4300: 绝世好题
    Codevs 2185【模板】最长公共上升子序列
    P1439 【模板】最长公共子序列
    P3865 【模板】ST表
    【转】良心的可持久化线段树教程
    Codevs 1299 切水果
    P3388 【模板】割点(割顶)&& 桥
    P3805 【模板】manacher算法
  • 原文地址:https://www.cnblogs.com/cshi/p/5449725.html
Copyright © 2011-2022 走看看