hello~大家每天好,我是小小前端-libei
最近在开发uni中,因业务需要无法使用组件的轮播图,尝试用的uniapp内置组件swiper,然后就发现了一个坑,这个swiper组件必须给高度!!!
那么问题来了,如果把swiper定死了高度,那整体的高度不会随着子内容的变化而变化,也无法很好的适应其他机型
所以我用到了uni提供的api-uni.createSelectorQuery来获取容器的实际高度,再赋值给swiper组件作为动态样式
使用的时候又发现!!!uni.createSelectorQuery获取的高度与容器实际高度不符,原以为是视图数据渲染问题,发现加了$nextTick也没用,查了一系列资料,最后使用到了定时器setTimeout
getElementTop() {
setTimeout(() => {
uni
.createSelectorQuery()
.in(this)
.select(".swiper-container")
.boundingClientRect((data) => {
if (data) {
this.swiperHeight = data.height + 30;
}
})
.exec();
}, 0);
},
这样获取到的高度就是准确的,不过还是不清楚其中的原理,只能说,uni的坑太多了!!!