一盏茶的功夫带你掌握烦人的 this 指向问题( 一 )

简介: 一盏茶的功夫带你掌握烦人的 this 指向问题( 一 )

前言

相信很多小伙伴们都被this 的指向问题所折磨过,this 它到底指向哪啊? 今天我们就来聊聊如何判断this 指向哪里,一盏茶的功夫让小伙伴们开心一整天!

文中所实例代码都运行在Chrome浏览器的Console控制台中。

先带大家了解一个概念,在浏览器中运行代码时,window对象就是全局,因此所有在全局作用域中声明的变量,函数都会变成window对象的属性和方法。

this 的绑定规则

  1. 默认绑定 --- 函数在哪个词法作用域里生效,this就指向哪里

我们用通俗易懂的话来说:

在非严格模式下,当函数调用时无任何调用前缀的情景,也就是直接调用函数,(后面我们会介绍非直接调用的情况),this 指向全局,在浏览器中也就是window

我们来看一个简单的例子:

var a = 1
 function foo() {
   console.log(this.a);
 }
 foo()

在此例子中,foo()就是直接调用,那么函数中的this就指向全局区,那么this.a输出1

image.png

再来看一个稍微复杂的例子:

var b = 2
function foo() {  // [[scope]]
  var b = 1
  function bar() {
    baz()
  }
  function baz() {
    console.log(this.b);
  }
  bar()
}
foo()

这个例子中无论函数声明在哪,在哪调用,由于函数调用时前面并未指定任何对象,而是直接调用,这种情况下this指向全局,输出2

image.png

2. 隐式绑定 --- 当函数被一个对象所拥有,再调用时,此时this会指向该对象

如果函数被一个对象作为方法所调用时,那么this就会指向该对象。我们来看一个例子:

function foo() {
    console.log(this.a);
  }
  var obj = {
    a: '来颗奇趣蛋',
    func: foo
}
obj.func()

foo函数体被对象obj所拥有,当obj调用时,this就会指向obj

我们来看看输出结果:

image.png

3. 隐式丢失 --- 当函数被多个对象链式调用时,this指向引用函数的对象

通俗一点来说呢,比如有两个对象object 和 obj,例如这样调用一个函数,obj.object.func(),那么this会指向object(object所引用),也可以说就近原则

我们来看一个例子:

function foo() {
    console.log(this.a);
  }
  
var obj2 = {
    a: '菌菌',
    obj: obj
}
var obj = {
  a: '来颗奇趣蛋',
  func: foo
}
obj2.obj.func()

objobj2所拥有时,而函数被obj所拥有,当函数被这样调用时obj2.obj.func(),this指向所引用函数的obj

让我们来看看输出:

image.png

怎么样,是不是解决了你对this指向的问题的一大半疑惑,下篇文章我会讲剩下的两种方法,小伙伴们记得一起来看看。

今天的内容就到这啦,如果你觉得小编写的还不错的话,或者对你有所启发,请给小编一个辛苦的赞吧

目录
打赏
0
2
3
0
43
分享
相关文章
学Python静不下来,看了一堆资料还是很迷茫是为什么
学Python静不下来,看了一堆资料还是很迷茫是为什么
74 2
学Python静不下来,看了一堆资料还是很迷茫是为什么
军品怎能在民用前踌躇?——答军校里出来的地方生
【来信】尊敬的贺老师:       我是某军事院校的一名研究生,因为我是地方生但是我现在所学的方向在地方可能根本用不到。然后我真正感兴趣的是图像处理,模式识别这个方向。我现在很迷茫不知道该怎么办,要不要自己自学一下我刚兴趣的方向。我通过CSDN看到了贺老师的博客,对您十分崇拜,然后我也加了您的人人,就是想向您学习。您也是我人生路上的一位良师。所以在我迷茫之时想请贺老师在百忙之中来指点一二。 【
1369 0
溜着弯儿就能黑掉身边的人,他是怎么做到的?
本文讲的是溜着弯儿就能黑掉身边的人,他是怎么做到的?,近几年,物联网设备越来越普及,办公室和家里都已经配备了大量物联网设备,比如说,智能打印机、咖啡机、智能遥控器等。开发出这些智能设备的初衷都是非常美好的——解放人类的双手,只要连接了互联网,只要轻轻按下按钮即可执行操作。
1495 0
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法

热门文章

最新文章