• javascript apply()和call()


    原文链接 http://www.jb51.net/article/30883.htm

    想要理解透彻apply()和call() ,还要需要理解this  作用域 局部变量  全局变量 

    js apply()和call() 

    1、每个函数都包含两个非继承而来的方法:apply()和call()。 
    2、他们的用途相同,都是在特定的作用域中调用函数。 
    3、接收参数方式不同
        apply()接收两个参数,一个是函数运行的作用域(this),另一个是参数数组。     call()方法第一个参数与apply()方法相同,但传递给函数的参数必须列举出来。
    例1:
    复制代码 代码如下:
    window.firstName = "diz"; 
    window.lastName = "song"; 
    var myObject = { firstName: "my", lastName: "Object" }; 
    function HelloName() { 
      console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); 
    } 
    HelloName.call(window); //huo .call(this); 
    HelloName.call(myObject); 
    
    运行结果为: 
    Hello diz song glad to meet you! 
    Hello my Object glad to meet you! 

    例2: 
    复制代码 代码如下:
    function sum(num1, num2) { 
    return num1 + num2; 
    } 
    console.log(sum.call(window, 10, 10)); //20 
    console.log(sum.apply(window,[10,20])); //30 
    分析:在例1中,我们发现apply()和call()的真正用武之地是能够扩充函数赖以运行的作用域



    如果我们想用传统的方法实现,请见下面的代码:
    window.firstName = "diz"; 
    window.lastName = "song"; 
    var myObject = { firstName: "my", lastName: "Object" }; 
    function HelloName() { 
    console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); 
    } 
    HelloName(); //Hello diz song glad to meet you! 
    myObject.HelloName = HelloName; 
    myObject.HelloName(); //Hello my Object glad to meet you! 

    要想让HelloName()函数的作用域在对象myObject上,
    需要动态创建myObject的HelloName属性,此属性作为指针指向HelloName()函数,
    这样,当我们调用myObject.HelloName()时,函数内部的this变量就指向myObjecct,也就可以调用该对象的内部其他公共属性了。

      

    再看一看函数中定义函数时,this变量的情况 

    function temp1() { 
    console.log(this); //Object {} 
    function temp2() { 
    console.log(this); //Window 
    } 
    temp2(); 
    } 
    var Obj = {}; 
    temp1.call(Obj); //运行结果见上面绿色的注释!!!! 

    执行结果与下面的相同:
    function temp1() {
    console.log(this);
    temp2();
    }
    function temp2() {
    console.log(this);
    }
    var Obj = {};
    temp1.call(Obj);  

    4、bind()方法
      支持此方法的浏览器有IE9+、Firefox4+、Safari5.1+、Opera12+、Chrome。它是属于ECMAScript5的方法。直接看例子: 
     

    window.color = "red"; 
    var o = { color: "blue" }; 
    function sayColor(){ 
    alert(this.color); 
    } 
    var OSayColor = sayColor.bind(o); //这里使用的函数名,没有带括号
    OSayColor(); //blue 

     这里,sayColor()调用bind()方法,并传入o对象,返回了OSayColor()函数,在OSayColor()中,this的值就为o对象。

    请把你的疑问评论在下方。
  • 相关阅读:
    【题解】洛谷P1896 [SCOI2005] 互不侵犯(状压DP)
    [BZOJ4383][POI2015] Pustynia-[线段树+dp+拓扑排序]
    [agc016E]Poor Turkeys
    [arc082E]ConvexScore-[凸包]
    [BZOJ4011][HNOI2015]落忆枫音-[dp乱搞+拓扑排序]
    [arc062E]Building Cubes with AtCoDeer
    [arc079F]Namori Grundy
    [agc006F]Blackout
    [BZOJ4444][SCOI2015]国旗计划-[ST表]
    [BZOJ1007][HNOI2008]水平可见直线-[凸包]
  • 原文地址:https://www.cnblogs.com/zzcit/p/5672971.html
Copyright © 2020-2023  润新知