• 熟练掌握js中this的用法,解析this在不同应用场景的作用


    由于其运行期绑定的特性,JavaScript 中的 this 含义要丰富得多,它可以是全局对象、当前对象或者任意对象,这完全取决于函数的调用方式。
    JavaScript 中函数的调用有以下几种方式:作为函数调用,作为对象方法调用,作为构造函数调用,和使用 apply 或 call 调用。下面我们将按照调用方式的不同,分别讨论 this 的含义。
    情况一:纯粹的函数调用
    这是函数的最通常用法,属于全局性调用,因此this就代表全局对象Global。
    1、函数也可以直接被调用,此时 this 绑定到全局对象。
    function makeNoSense(x) { 
        this.x = x; 
    } 
    makeNoSense(5); 
    console.log(x);// x 已经成为一个值为 5 的全局变量
    function test(){
      this.x = 1;
      alert(this.x);
    }
    test(); // 1

    情况二:作为对象方法的调用

    函数还可以作为某个对象的方法调用,这时this指代对象内部属性被调用。

    var myObject = {
      value :0,
      increment:function (inc){
        this.value += typeof inc ==='number' ? inc:1;
      }
    };
    myObject.increment();
    console.log(myObject.value);  //1
    myObject.increment(2);
    console.log(myObject.value);  //3

    情况三 :作为构造函数调用

    javaScript 支持面向对象式编程,与主流的面向对象式编程语言不同,JavaScript 并没有类(class)的概念,而是使用基于原型(prototype)的继承方式。
    相应的,JavaScript 中的构造函数也很特殊,如果不使用 new 调用,则和普通函数一样。作为又一项约定俗成的准则,构造函数以大写字母开头,提醒调用者使用正确的方式调用。如果调用正确,this 绑定到新创建的对象上。
    所谓构造函数,就是通过这个函数生成一个新对象(object)。这时,this就指这个新对象。
    function Point(x, y){ 
        this.x = x; 
        this.y = y; 
     }
    var p1 = new Point(3,2);
    console.log(p1.x+","+p1.y);//3,2

    为了表明这时this不是全局对象,我对代码做一些改变:

    var x = 4;
    function Point(x, y){ 
        this.x = x; 
        this.y = y; 
     }
    var p1 = new Point(3,2);
    console.log(p1.x+","+p1.y);//3,2

    情况四: apply或call调用

    让我们再一次重申,在 JavaScript 中函数也是对象,对象则有方法,apply 和 call 就是函数对象的方法。这两个方法异常强大,他们允许切换函数执行的上下文环境(context),即 this 绑定的对象。很多 JavaScript 中的技巧以及类库都用到了该方法。让我们看一个具体的例子:
    function Point(x, y){ 
        this.x = x; 
        this.y = y; 
        this.moveTo = function(x, y){ 
            this.x = x; 
            this.y = y; 
            console.log(this.x+","+this.y);
        } 
    } 
    var p1 = new Point(0, 0); 
    var p2 = {x: 0, y: 0}; 
    p1.moveTo(1, 1); //1,1
    p1.moveTo.apply(p2, [10, 10]);//10,10

    在上面的例子中,我们使用构造函数生成了一个对象 p1,该对象同时具有 moveTo 方法;使用对象字面量创建了另一个对象 p2,我们看到使用 apply 可以将 p1 的方法应用到 p2 上,这时候 this 也被绑定到对象 p2 上。另一个方法 call 也具备同样功能,不同的是最后的参数不是作为一个数组统一传入,而是分开传入的。本文通过对JavaScript中经常容易混淆的this在四中应用场景中的使用方法进行了讲解,希望对您有所帮助,喜欢的话,请推荐一下哦。

  • 相关阅读:
    Java中基于线程池的任务调度设计
    Java中数值型,字符型及字符串的相互转换
    Java编程中必备的十种技能
    Java键盘读入方法
    Java中数据类型及运算符的注意事项
    Java抽象类是否可继承实体类
    Java多线程:start(),sleep(),yield(),join()
    Java线程静态在对象缓存中的妙用
    webAPI
    javascript中的作用域和变量提升
  • 原文地址:https://www.cnblogs.com/wdlhao/p/5764456.html
Copyright © 2020-2023  润新知