但是现在问题是父组件的数据是异步获取的,而子组件一开始就会渲染,如果此时没有传入数据,而子组件又要用到数据中的length属性时就会报错:
怎么办呢?最简单的办法就是让子组件条件渲染,当有数据的时候才渲染,这样就不会抛出错误了。
但是这还不够完美,子组件一般不直接使用父组件传来的值,二是监听一下,然后有变化了的时候再赋值给data,渲染的时候用data里的数据,这样就能保证随时动态更新数据
-
props: ['floorGoods'],
-
data() {
-
return{
-
flGoods: {}
-
}
-
},
-
watch: {
-
floorGoods(val) {
-
this.flGoods = val;
-
console.log(val);
-
}
-
}
在一个方法就是在父组件里用Promise方法异步执行数据的赋值:
-
new Promise((resolve,reject) => {
-
if (res.status === 200){
-
resolve(res);
-
}
-
}).then((res) => {
-
this.category = res.data.data.category;
-
this.adBar = res.data.data.advertesPicture.PICTURE_ADDRESS;
-
this.bannerSwipePics = res.data.data.slides;
-
this.recommendGoods = res.data.data.recommend;
-
// 也可异步获取再传给子组件 Promise
-
this.floorSeafood = res.data.data.floor1;
-
this.floorBeverage = res.data.data.floor2;
-
this.floorFruits = res.data.data.floor3;
-
console.log(this.floorFruits);
-
this._initScroll();
-
})
-
}).catch(err => {
-
console.log(err);
-
});
这样也是可以的,异步获取数据导致的报错的情况会在各个场景出现,比如根据数据渲染dom,而对dom有js操作的时候,会因为还没渲染出来而找不到响应的dom元素报错,这里可以用vue提供的$nextTick()函数,或者手动开个setTimeout定时器,延迟获取;使用better-scroll的时候因为dom没有渲染出来而无法获取滚动元素的高度,导致无法滚动,同样可以用vue提供的这个函数,等dom渲染完了后再初始化滚动。