欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js中this对象用法分析

程序员文章站 2022-08-10 08:34:26
this对象是在函数运行时,基于函数的执行环境绑定的。 其实这句话的本质就是,谁调用了函数,this就指向谁 具体的来说,通常有以下几种情况: 全局函数 在...

this对象是在函数运行时,基于函数的执行环境绑定的。

其实这句话的本质就是,谁调用了函数,this就指向谁

具体的来说,通常有以下几种情况:

全局函数

在全局环境中,this指向window

//例子1
 function a() {
 console.log(this)
 }
 a();//window

上面的例子很简单,函数a在全局环境中执行,也就是全局对象window调用了函数。此时this指向window

对象方法

作为对象方法调用时,this指向调用该方法的对象

//例子2
var b = {
 getthis:function(){
  console.log(this)
 }
}
b.getthis()//b

到这里我们举的例子都比较简单易懂,接下来来一个有意思的:

//例子3
 var c = {
 getfunc:function(){
  return function(){
  console.log(this)
  }
 }
 }
 var cfun = c.getfunc()
 cfun()//window

这个例子和前一个例子不一样,运行c.getfunc()时,首先返回的是一个匿名函数,我们将这个函数赋值给cfun,接着在全局环境中调用了cfun(),所以此时this指向的还是window。

如果我们一定要让这里返回的是c对象呢?在开头我们说过,this对象是在函数执行时确定的,在例子3中,执行c.getfunc()时,this对象指向的还是c,所以我们只要保持住这个this就好了,对上面的代码稍微改动:

//例子4
 var c = {
 getfunc:function(){
  var that = this //在这里保留住this
  return function(){
  console.log(that)
  }
 }
 }
 var cfun = c.getfunc()
 cfun()//c

这也就是我们经常可以在一些代码中看到var self = this或者var that = this之类的原因了。

call和apply

此时this对象通常指向函数中指定的this值(注意这里的通常2字,考试要考的)

call和apply算是老生常谈,但还是稍微介绍下,怕新同学可能没接触过(其实是为了凑点字数),拿call来说,语法是这样的

fun.call(thisarg, arg1, arg2, ...)

这个方法怎么用呢,看下面的例子:

//例子5
var d = {
 getthis:function(){
  console.log(this)
 }
}
var e = {
 name:'e'//(给e写个`name`属性只是因为觉得孤零零的太难看了~~)
}
d.getthis.call(e)//e

在这里我们就可以看出call函数的意思了:指定一个对象o1去调用其他对象o2的方法,此时this对象指向o1

好了,那为什么前面我们说通常呢?因为,这里的thisarg是可以指定为null和undefined的。请看:

//例子6
var d = {
 getthis:function(){
  console.log(this)
 }
}
 d.getthis.call(null)//window
 d.getthis.call(undefined)//window

此时的this指向全局对象window

箭头函数

es6中的箭头函数现在也用的比较频繁,但是有个需要注意的点是:

函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

其实出现这种情况的根本原因是:箭头函数没有this对象,所以箭头函数的this就是外层代码的this

//例子7
 var f = {
  getthis:()=>{
   console.log(this)
  }
 }
 f.getthis()//window

这个例子和前面例子2是基本一样的,只是把普通函数改写成箭头函数,但是此时的this对象已经指向了外层的window。

考虑到这一点可能不好理解,我们再看几个例子:

//例子8
 var g = {
 getthis:function(){
  return function(){console.log(this)}
 }
 }
 var h = {
 getthis:function(){
  return ()=> console.log(this)
 }
 }
 g.getthis()()//window
 h.getthis()()//h

这个例子里,g的getthis写法就和之前的例子3一样,由于函数在全局环境中运行,所以此时this指向window;h的getthis使用了箭头函数,所以this指向了外层代码块的this所以,此时this指向的是h。

总结

一般情况下this对象指向调用函数的对象,全局环境中执行函数this对象指向window

在call和apply函数中this指向指定的对象,如果指定的对为undefined或者null,那么this对象指向window

在箭头函数中,this对象等同于外层代码块的this

然后依然是每次都一样的结尾,如果内容有错误的地方欢迎指出;如果对你有帮助,欢迎点赞和收藏,感谢你对的支持。