this关键字 6个月前

编程语言
399
this关键字

this 关键字

作用

this可以用在构造函数之中,表示实例对象( javascript对象篇有提及, 非常简单易懂) this有一个特点:它总是返回一个对象this就是属性或方法“当前”所在的对象。

this.property // this此时就代表property属性当前的对象。

下面是一个实际的例子。

var person = {
  name: 'xiaobai',
  describe: function () {
    return 'name:'+ this.name;
  }
};

person.describe()
// "name:xiaobai"

由于this.name是在describe方法中调用,而describe方法所在的当前对象是person 因此this指向personthis.name就是person.name

由于对象的属性可以赋给另一个对象,所以属性所在的当前对象是可变的,即this的指向是可变的。

var A = {
  name: 'daitu',
  describe: function () {
    return 'name:'+ this.name;
  }
};
var B = {
  name: 'xiaobai'
};
B.describe = A.describe;
B.describe()
// "name:xiaobai"

上面代码中,A.describe属性被赋给B,于是B.describe就表示describe方法所在的当前对象是B,所以this.name就指向B.name

使用

全局环境

function f() {
  console.log(this === window);
}
f() // true

不管是不是在函数内部,只要是在全局环境下运行,this就是指顶层对象window

构造函数

构造函数中的this,指的是实例对象。

var Obj = function (p) {
  this.p = p;
};

上面代码定义了一个构造函数Obj。由于this指向实例对象,所以在构造函数内部定义this.p,就相当于定义实例对象有一个p属性。

var o = new Obj('Hello World');
o.p // "Hello World!"

对象的方法

如果对象的方法里面包含thisthis的指向就是方法运行时所在的对象。该方法赋值给另一个对象,就会改变this的指向。 这条规则不容易把握

var obj ={
  foo: function () {
    console.log(this);
  }
};

obj.foo() // obj

上面代码中,obj.foo方法执行时,它内部的this指向obj

但是,下面这几种用法,都会改变this的指向。

// 情况一
(obj.foo = obj.foo)() // window
// 情况二
(false || obj.foo)() // window
// 情况三
(1, obj.foo)() // window

上面代码中,obj.foo就是一个值。这个值真正调用的时候,运行环境已经不是obj了,而是全局环境,所以this不再指向obj

可以这样理解,JavaScript 引擎内部,objobj.foo储存在两个内存地址,称为地址一和地址二。 obj.foo()这样调用时,是从地址一调用地址二,因此地址二的运行环境是地址一,this指向obj。 但是,上面三种情况,都是直接取出地址二进行调用,这样的话,运行环境就是全局环境,因此this指向全局环境。上面三种情况等同于下面的代码。

// 情况一
(obj.foo = function () {
  console.log(this);
})()
// 等同于
(function () {
  console.log(this);
})()

// 情况二
(false || function () {
  console.log(this);
})()

// 情况三
(1, function () {
  console.log(this);
})()

如果this所在的方法不在对象的第一层,这时this只是指向当前一层的对象,而不会继承更上面的层。

简单说明this使用需要避免的问题

  • 避免多层this
  • 避免数组处理方法中的this
  • 避免回调函数中的this
image
EchoEcho官方
无论前方如何,请不要后悔与我相遇。
1377
发布数
439
关注者
2243401
累计阅读

热门教程文档

Next
43小节
Docker
62小节
Vue
25小节
Spring Boot
24小节
QT
33小节