vue2知识点:箭头函数和普通函数的this指向问题

简介: vue2知识点:箭头函数和普通函数的this指向问题

image.png

@[toc]

摘要

记录此文章是因为本人是vue初学者,刚看完尚硅谷的教学视频,到现在为止对箭头函数和普通函数的this指向问题直接弄混了,所以特意查阅相关博客并记录下自己的总结。

主要区别

  • 普通函数:(谁调用我,我的this就指向谁)
  • 箭头函数:(箭头函数没有自己的this, 它的this是继承而来, 它会捕获其所在(即定义的位置)上下文的this值, 作为自己的this值;或者说默认指向在定义它时所处的对象(宿主对象),而不是执行时的对象。)

    详细说明

    注意点1:
    不被vue所管理的函数(定时器的回调函数、ajax的回调函数等、Promise的回调函数=》JS引擎帮忙调用)那么请使用箭头函数,因为箭头函数中this指代vm或者vc。

注意点2:
所有被Vue管理的函数(Vue帮忙调用),最好写成普通函数(普通函数中的this代表它的直接调用者,如obj.fn(),fn的this指向就是obj。默认情况下,没有直接的调用者,this的指向为window),这样this的指向才是vm 或 组件实例对象。

举例

普通函数情况

  1. 在全局函数中,普通函数中this =》window
  2. 当普通函数被作为某个对象的方法调用时,this就等于那个对象

计算属性computed和监视属性watch情况

  1. 计算属性使用同步操作的普通函数,this => vue,
  2. 计算属性使用同步操作的箭头函数,this => window
  3. 监视属性使用同步操作的普通函数,this => vue,
  4. 监视属性使用同步操作的箭头函数,this => window,
  5. 监视属性使用异步操作的普通函数,this => window,
  6. 监视属性使用异步操作的箭头函数,this => vue

父子组件通信使用\$refs.组件名称.\$on('自定义事件名', 配置项)情况

在父组件App中使用\$on的普通函数this指代子组件的vc,而\$on的箭头函数this指代父组件的vc,所以\$on的普通函数的this.studentName = name就会赋值失败,正确写法就是上面说的,要么method定义赋值,\$on中直接调用,要么\$on中使用箭头函数去赋值

mounted() {
   
this.$refs.student.$on('atguigu',function (name,...params) {
   
      console.log('App收到了学生名:',name,params)
      console.log("this:", this);  //使用自定义组件的配置项的普通函数中this指代子组件Student.vue的vc
      this.studentName = name
    }) //绑定自定义事件
}
---------------------------------------------------------------------------------------
mounted() {
   
this.$refs.student.$on('atguigu',(name,...params) => {
   
      console.log('App收到了学生名:',name,params)
      console.log("this:", this); //使用自定义组件的配置项的箭头函数中this指代父组件App.vue的vc
      this.studentName = name
    }) //绑定自定义事件
}

生命周期钩子函数中(如beforeCreate,created,beforeMount,mounted,beforeUpdate, updated,beforeDestroy以及destroyed)

this指代vue对象

总结

哪怕总结了这么多种情况,但是你要是问我,什么情况使用普通函数,什么情况使用箭头函数,我的回答是:

  • 不被vue所管理的函数(定时器的回调函数、ajax的回调函数等、Promise的回调函数=》JS引擎帮忙调用)那么请使用箭头函数。
  • 计算属性computed和监视属性watch直接用普通函数
  • 除上述2种情况外,所有方法都在methods中定义好,不要在$on的配置项中去定义函数;另外如果你怕this指向混乱,你直接在外部定义个变量去存储当前vue组件的vm或者vc。举例说明就是,你要使用\$on去触发自定义事件,你先定义一个变量存储当前组件的vm和vc,然后你在\$on的配置项的函数中直接用定义好的那个this变量去设置值,不要在配置项中的函数中用this,因为你不知道局部方法中这个this指向谁。
目录
相关文章
|
4月前
|
JavaScript 前端开发
forEach与map的区别
forEach与map的区别
293 0
|
存储 关系型数据库 MySQL
介绍一下MySQL的一些应用场景
【10月更文挑战第17天】介绍一下MySQL的一些应用场景
2803 0
|
11月前
|
API
鸿蒙开发:简单了解属性动画
无论是是使用animateTo还是animation,其实最终要改变的都是组件的可执行属性,最终的效果是一致的,animateTo是闭包内改变属性引起的界面变化,一般作用于出现消失转场,而animation则是组件通过属性接口绑定的属性变化引起的界面变化,一般使用场景为,animateTo适用对多个可动画属性配置相同动画参数的动画,需要嵌套使用动画的场景;animation适用于对多个可动画属性配置不同参数动画的场景。
363 4
鸿蒙开发:简单了解属性动画
|
传感器 监控 安全
|
Kubernetes jenkins 持续交付
Jenkins 插件生态:提升自动化能力
【8月更文第31天】Jenkins 是一个开源的持续集成/持续交付(CI/CD)平台,广泛应用于软件开发的各个阶段。Jenkins 的一大特色就是其丰富的插件生态系统,这些插件极大地扩展了 Jenkins 的功能,使其能够适应各种各样的应用场景。本文将深入探讨 Jenkins 的插件生态系统,并指导如何选择和配置插件以满足特定需求。
616 1
|
移动开发 Python
综合评价法之秩和比法RSR
介绍秩和比法的应用,及其代码实现
1607 0
综合评价法之秩和比法RSR
|
前端开发
CSS动画(毛玻璃按钮)
CSS动画(毛玻璃按钮)
|
存储 前端开发 Java
Android应用开发中的MVP架构模式实践
【5月更文挑战第5天】随着移动应用开发的复杂性增加,传统的MVC(Model-View-Controller)架构在应对大型项目时显得笨重且不灵活。本文将探讨一种更适应现代Android应用开发的架构模式——MVP(Model-View-Presenter),并展示如何在Android项目中实现该模式以提升代码的可维护性和可测试性。通过对比分析MVP与传统MVC的差异,以及提供一个实际案例,读者将能深入了解MVP的优势和实施步骤。
292 9
|
JavaScript 前端开发 API
Vue.js 深度解析:nextTick 原理与应用
Vue.js 深度解析:nextTick 原理与应用
|
存储 前端开发 Java
SpringBoot实现简单的登录验证码
SpringBoot实现简单的登录验证码
930 0
下一篇
oss云网关配置