我想做这样的事情mounted() {}
:
await fetchData1();
await fetchData2UsingData1();
doSomethingUsingData1And2();
所以我想知道这是否有效:
async mounted() {
await fetchData1();
await fetchData2UsingData1();
doSomethingUsingData1And2();
},
在我的环境中,它不会引发任何错误,并且似乎运行良好。
但在这个问题上,async/await
生命周期钩子没有实现。
https://github.com/vuejs/vue/issues/7209 https://github.com/vuejs/vue/issues/7209
我找不到更多信息,但实际上可以吗?
它会起作用,因为mounted
钩子被调用after该组件已经安装,换句话说,它不会在渲染之前等待承诺解决。唯一的问题是,在承诺解决之前,您将拥有一个“空”组件。
如果您需要的是在数据准备好之前不呈现组件,则您的数据中需要一个与v-if
当一切准备就绪时渲染组件:
// in your template
<div v-if="dataReady">
// your html code
</div>
// inside your script
data () {
return {
dataReady: false,
// other data
}
},
async mounted() {
await fetchData1();
await fetchData2UsingData1();
doSomethingUsingData1And2();
this.dataReady = true;
},
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)