问题:
父组件向子组件传递值时,发现子组件没有渲染,在子组件中打印时发现获取到的值是空。

原因:
父组件加载页面时就开始传值了,但是数据请求走的慢,没有拿到数据

解决:
在子组件中加个布尔值默认值为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
				}
			})
		}
	}
 }
Logo

前往低代码交流专区

更多推荐