文章详情页
javascript - vue渲染子组件异步问题
浏览:173日期:2023-01-07 15:56:33
问题描述
现在有一个组件A。里面包含了组件B,C,D,由于涉及了数据共享,组件B需要用x参数发请求,但是x参数是在A里面发请求获取到的,现在出现的问题是在A还没获取到参数x的时候B就已经先一步发请求了(结果请求400错误),出现问题的根本问题是父组件与子组件的渲染都是异步进行的,在父组件获取参数时用了async+await。
async beforeMount(){ let x = await this.getCityInfo(); this.GET_POSITION(x); console.log(11);},
现在目前能想到的方案就将B,C,D全部整合到A内部,使A内部没有子组件,这样就不会有组件之间异步渲染的问题,请问还有其他更好的方案吗?
问题解答
回答1:获取 x 成功之前不渲染 B
<B v-if='x'></B>
或者 B 自己 watch prop x ,值不对不发请求。
watch: { x (value) { if (value) { // send request } }}回答2:
A请求完了emit一个事件 B去监听就是了
标签:
JavaScript
相关文章:
1. golang - 用IDE看docker源码时的小问题2. css - ul ol前边的标记如何调整样式呢3. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?4. dockerfile - 为什么docker容器启动不了?5. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!6. dockerfile - [docker build image失败- npm install]7. css - chrome浏览器input记录上次cookie信息后,有个黄色背景~如何去除!8. html - 爬虫时出现“DNS lookup failed”,打开网页却没问题,这是什么情况?9. mac连接阿里云docker集群,已经卡了2天了,求问?10. 用CSS3 box-sizing 属性实现两个并排的容器,如果想让容器中间有间隔该如何实现
排行榜

网公网安备