软件教程 2025年08月6日
0 收藏 0 点赞 296 浏览 1296 个字
摘要 :

文章目录 前言 this 的绑定规则 默认绑定 2. 隐式绑定 3. 隐式丢失 总结 本文重点讲解前端this指向问题,我们来一起学习下! 前言 相信很多小伙伴们都被this 的指向……




  • 前言
  • this 的绑定规则
    • 默认绑定
    • 2. 隐式绑定
    • 3. 隐式丢失
  • 总结

本文重点讲解前端this指向问题,我们来一起学习下!

前言

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

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

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

this 的绑定规则

默认绑定

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

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

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

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

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

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

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

var b = 2
function foo() {  // [[scope]]
  var b = 1

  function bar() {
    baz()
  }
  function baz() {
    console.log(this.b);
  }
  bar()
}

foo()

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

2. 隐式绑定

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

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

function foo() {
    console.log(this.a);
  }
  var obj = {
    a: \'潘子夜个人博客www.panziye.com\',
    func: foo
}
obj.func()

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

输出结果:潘子夜个人博客www.panziye.com

3. 隐式丢失

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

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

我们来看一个例子:

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

  
var obj2 = {
    a: \'哈哈\',
    obj: obj
}
var obj = {
  a: \'潘子夜个人博客www.panziye.com\',
  func: foo
}
obj2.obj.func()

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

输出结果:潘子夜个人博客www.panziye.com

总结

以上就是前端this指向问题详解的全部内容,怎么样,是不是解决了你对this指向的问题的一大半疑惑呢,希望对有帮助!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/6382.html

管理员

相关推荐
2025-08-06

文章目录 一、Promise基础回顾 二、Promise 与 axios 结合使用场景及方法 (一)直接返回 axios …

270
2025-08-06

文章目录 一、模块初始化时的内部机制 二、常见导出写法的差异分析 (一)写法一:module.exports…

108
2025-08-06

文章目录 一、ResizeObserver详解 (一)ResizeObserver是什么 (二)ResizeObserver的基本用法 …

684
2025-08-06

文章目录 一、前期准备工作 (一)下载相关文件 (二)安装必要工具 二、处理扣子空间生成的文件…

340
2025-08-06

文章目录 一、官方文档 二、自动解包的数据类型 ref对象:无需.value即可访问 reactive对象:保持…

371
2025-08-06

文章目录 一、Hooks的工作原理 二、在if语句中使用Hook会出什么岔子? 三、React官方的Hook使用规…

844
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号