• Vue中关于this指向的问题


    由Vue管理的函数

    例如:

    • computed 计算属性
    • watch 监视属性
    • filters (Vue3中已弃用且不再支持) 过滤器
    • ....

    上述属性里配置的函数不要采用箭头函数写法,因为箭头函数没有自己的this对象,使用this时会向外找到window,不会指向Vue实例,也就调用不到Vue中的数据。

    不被vue管理的函数

    例如:

    • setTimeout计时器里的回调函数
    • setInterval定时器里的回调函数
    • ajax请求里的回调函数
    • ....

    上述回调函数(除定时器外)使用普通函数定义的话,里面的this指向的是window,定时器中this指向undifined(这个死磕了老长时间,vscode没提示,换webstorm调试出来的...)

    用箭头函数时,this会向函数外找,找到Vue实例(因为在vue环境里嘛)。

    this指向大致分类

    奉上 菜鸟教程(yyds) 里大佬总结的

    • 在对象方法中, this 指向调用它所在方法的对象。
    • 单独使用 this,它指向全局(Global)对象。
    • 函数使用中,this 指向函数的所属者。
    • 严格模式下函数是没有绑定到 this 上,这时候 this 是 undefined。
    • 在 HTML 事件句柄中,this 指向了接收事件的 HTML 元素。
    • apply 和 call 允许切换函数执行的上下文环境(context),即 this 绑定的对象,可以将 this 引用到任何对象。

    附上 菜鸟中介绍this的直达链接:this详解

    总结

    在Vue环境里:

    • 由Vue管理的函数,尽量使用普通函数定义。
    • 不被Vue管理的函数,尽量使用箭头函数定义。
    • 监视属性里的普通函数,函数体里要使用定时器的话,要用箭头函数来定义定时器。(举个栗子)

    这样保证this总是指向Vue实例,可以调用到Vue数据。


    有很多前辈写的太高奥了,,越看越迷都迷了,,这里写个总结当备忘,足够用了,以后有时间了学透了再补充


    __EOF__

  • 本文作者: mojospy
  • 本文链接: https://www.cnblogs.com/mojospy/p/16496422.html
  • 关于博主: I am a good person
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
  • 声援博主: 如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。
  • 相关阅读:
    VUE3 之 全局 Mixin 与 自定义属性合并策略 - 这个系列的教程通俗易懂,适合新手
    MATLAB与Excel的数据交互
    JavaWeb项目部署到服务器并连接本地数据库(超详细!)
    【VUE项目实战】63、指定打包入口及加载外部CDN资源
    【国际竞赛-计算机篇】2022年高含金量的计算机竞赛有哪些
    轻量级自动化测试框架WebZ
    Linux中设置git的代理
    Hadoop的HDFS高可用方案
    华为配置基于VLAN限速示例
    Review-MyBatis
  • 原文地址:https://www.cnblogs.com/mojospy/p/16496422.html