为了账号安全,请及时绑定邮箱和手机立即绑定

大佬们遇到过这个问题吗?vue.js混入mixins谢谢哈~

大佬们遇到过这个问题吗?vue.js混入mixins谢谢哈~

蓝山帝景 2019-09-19 22:48:08
//init.jsconsthi={asynccreated(){awaitthis.getToken()}}//业务组件mixins:['init']asyncmounted(){awaitthis.getUserInfo()}上述代码为我开发了一个vue全局混入js,每个页面进入都会调用this.getToken(),然后这个方法返回一个token,而业务组件中this.getUserInfo()这个方法调用接口依赖于this.getToken()接口的返回值。目前的问题时,按照上述代码先执行的this.getToken(),后执行的this.getUserInfo(),但是我需要拿到第一个方法的返回值后再去调用this.getUserInfo()方法,但是现在第一个接口调用后,立马去调第二个接口,此时我还没有拿到第一个接口返回来的token。init.js为公共js这个问题应该怎么解决
查看完整描述

2 回答

?
largeQ

TA贡献2039条经验 获得超7个赞

解决方式很多种,在我看来最简单的方案就是在init.js后面触发个自定义钩子
consthi={
asynccreated(){
awaitthis.getToken()
this.getTokenAfter&&this.getTokenAfter()
}
}
然后把你写在mounted里面的方法放在methods下面这个自定义钩子里
methods:{
getTokenAfter:asyncfunction(){
awaitthis.getUserInfo()
},
                            
查看完整回答
反对 回复 2019-09-19
?
人到中年有点甜

TA贡献1895条经验 获得超7个赞

首先你的这种方式使用并不能保证生命周期函数之间是同步执行的,只能保证生命周期函数内部是同步执行的,你可以这样
//init.js
consthi={
asynccreated(){
awaitthis.getToken()
this.getUserInfo()
},
methods:{
getUserInfo(){}//啥都不写,具体在相关业务组件中重写即可
}
}
//业务组件
mixins:['init']
methods:{
getUserInfo(){
//你的具体业务代码
...
}
}
                            
查看完整回答
反对 回复 2019-09-19
  • 2 回答
  • 0 关注
  • 406 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信