您现在的位置是:网站首页> 编程资料编程资料
Vue中关于this指向的问题示例详解_vue.js_
2023-05-24
316人已围观
简介 Vue中关于this指向的问题示例详解_vue.js_
在Vue中,方法体里用this调用vue实例的数据,有时会指向window,导致调用失败报错。
由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数据。
到此这篇关于Vue中关于this指向的问题 的文章就介绍到这了,更多相关vue this指向内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- 微信小程序实现页面导航的方法详解_javascript技巧_
- vue中的el-button样式自定义方式_vue.js_
- 使用开源Cesium+Vue实现倾斜摄影三维展示功能_vue.js_
- JavaScript引入方式深入解读_javascript技巧_
- 微信小程序实现购物车页面_javascript技巧_
- Node.js 与并发模型的详细介绍_node.js_
- JavaScript创建对象的几种方式及关于this指向问题_javascript技巧_
- JS前端可扩展的低代码UI框架Sunmao使用详解_JavaScript_
- js+css实现计算器功能_javascript技巧_
- javascript中export 和export default的区别_javascript技巧_
