记录此文章是因为本人是vue初学者,刚看完尚硅谷的教学视频,到现在为止对箭头函数和普通函数的this指向问题直接弄混了,所以特意查阅相关博客并记录下自己的总结。
注意点1:
不被vue所管理的函数(定时器的回调函数、ajax的回调函数等、Promise的回调函数=》JS引擎帮忙调用)那么请使用箭头函数,因为箭头函数中this指代vm或者vc。
注意点2:
所有被Vue管理的函数(Vue帮忙调用),最好写成普通函数(普通函数中的this代表它的直接调用者,如obj.fn(),fn的this指向就是obj。默认情况下,没有直接的调用者,this的指向为window),这样this的指向才是vm 或 组件实例对象。
普通函数情况
计算属性computed和监视属性watch情况
父子组件通信使用$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对象
哪怕总结了这么多种情况,但是你要是问我,什么情况使用普通函数,什么情况使用箭头函数,我的回答是: