美文网首页
关于this指向的理解

关于this指向的理解

作者: ChenZi_Y | 来源:发表于2020-12-23 11:11 被阅读0次

平时遇到的this指向问题

例1

    function a() {
      this.a = 1;
      console.log(this);  // window
    }
    a();  // 执行a或者window.a后this指向到window
    const aa = new a();  // 构造函数方式 打印this为a {a: 1}
    console.log(aa.a); // => 1

例2

    const a = {
      a: 'isa',
      say: function(name) {
        console.log(this.a + ': ' + name)
      }
    }
    a.say('yuan')  // say方法this指向为a
    // 如果将say改变成es6箭头函数写法?
    const a = {
      a: 'isa',
      say: (name) => {
        console.log(this.a + ': ' + name)
      }
    }
    // 执行a.say
    a.say('yuan');
    // this.a 为undefined 因为箭头函数没有他自己的this,所以指向父级window

例3

    const a = {
      a: 'isa',
      say: function(name) {
        console.log(this.a + ': ' + name)
      }
    }
    function b(name) {
      this.a = 'isb';
      this.setA = (val) => {
        this.a = val;
      }
    }
    a.say('我叫a');  // => isa: 我叫a
    b.apply(a, ['1']); // b的this指向到a的this上
    b.call(a, '2');
    b.bind(a)('3');// or b.bind(a, '3');
    // apply, call, bind, 方法都可改变this的指向
    // 此时不改变a,通过b可以改变a的属性值
    a.say('我叫b');  // => isb: 我叫b
    
    // 现在我们希望利用b.setA方法动态改变this.a
    const bb = new b('bb');
    bb.setA(11);
    // 运行a.say发现this.a没有改为11,看例4使用prototype
    a.say('我叫11');  // => isb: 我叫11
    
    // 假如我们再加一个方法c,同时让它this指向b,也可以改变this.a
    function c() {
      this.c = 'c';
      this.a = 'isc';
    }
     c.call(b);  // 使用call改变this
     a.say('我叫c');  // => isb: 我叫c  并没有改变为isc
     // b的this指向是可以拿到,但是a的没有,需要通过b方法做指向
    function b(name) {
      this.a = 'isb';
      this.setA = (val) => {
        this.a = val;
      }
      c.call(this); // 写在b方法里
    }
    a.say('我叫c');  // => isc: 我叫c  通过c改变了a

例4

    const a = {
      a: 'isa',
      say: function(name) {
        console.log(this.a + ': ' + name)
      }
    }
    function b(name) {
      this.a = 'isb';
      this.setA = (val) => {
        this.a = val;
      }
      c.call(this);
    }
    function c() {
      this.c = 'c';
      this.a = 'isc';
    }
    b.prototype = a; 
    const bb = new b('bb');
    bb.say('我叫b');  // => isb: 我叫b
    bb.setA('setA');
    bb.say('我叫b, 改变了a');  // => setA: 我叫b, 改变了a

    c.prototype = new b('cc');
    const cc = new c();
    cc.say('我叫c');  // => isc: 我叫c

    b.prototype.newSay = function() {
      console.log(this.a);
    }
    bb.newSay();  // => setA
    // 可以发现后面在原型上增加的方法调用bb也是可以找到最后设置的setA

相关文章

  • 关于this指向的理解

    平时遇到的this指向问题 例1 例2 例3 例4

  • 关于js中this指向的理解

    https://www.cnblogs.com/pssp/p/5216085.html 上面那个例子是以前看的,现...

  • this指向的理解

    关于this指向,是这几天学微信小程序开发时才恶补的,所以理解的不是很全面,但是还是有很多的收获的,所以想记录下来...

  • objc 源码

    类的结构 关于isa的理解 由上图可知:实例变量的isa指向的是类,而类的isa指向的是元类(metaClass)...

  • 如何理解this的指向

    this是JS中一个关键字,this的指向是不确定的,可以动态改变,这样设计可以让代码更加灵活,复用性也更高,那么...

  • 简单理解this指向

    this的指向 函数中的this是在运行时候决定的,而不是函数定义时全局环境中的this指window其他函数中的...

  • 关于this指向

    1 首先this是和执行上下文绑定的,而执行上下文分为三种: (1) 全局执行上下文 在全局上下文中打印conso...

  • 关于this指向

    关于this指向 1.在全局函数下,函数内的this默认指向window2.在严格模式下,函数内的this指向un...

  • js关于this的理解,以及如何改变this的指向

    1.简述this 执行上下文中包含了变量环境、 词法环境、外部环境,this当一段代码被执行时,JavaScrip...

  • 如何理解JavaScript this的指向

    实习期间写代码时候就感觉this很迷。有些不知所措。后来查看了部分文章。 this最终指向的是调用它的对象(这个已...

网友评论

      本文标题:关于this指向的理解

      本文链接:https://www.haomeiwen.com/subject/fcdynktx.html