vue父子组件传值,父组件还没拿到数据传递给就传递给子组件了
问题:父组件向子组件传递值时,发现子组件没有渲染,在子组件中打印时发现获取到的值是空。原因:父组件加载页面时就开始传值了,但是数据请求走的慢,没有拿到数据解决:在子组件中加个布尔值默认值为false,获取数据前置为false;数据获取成功后置为true。<div><childv-if="flag" :point="list"/><div>default expo
·
问题:
父组件向子组件传递值时,发现子组件没有渲染,在子组件中打印时发现获取到的值是空。
原因:
父组件加载页面时就开始传值了,但是数据请求走的慢,没有拿到数据
解决:
在子组件中加个布尔值默认值为false, 获取数据前置为false; 数据获取成功后置为true。
<div>
<child v-if="flag" :point="list"/>
<div>
default export {
data(){
list:[]
// flag值为true,才会重新渲染组件
flag: false,
}
methods:{
getData(){
this.flag=false;
//这里是调用接口获取数据,接口数据获取成功将值置为true
getPoint().then(res=>{
if(res.code==200){
this.list=res.data
this.flag=true
}
})
}
}
}
更多推荐
已为社区贡献1条内容
所有评论(0)