作者:Sinea
来源:segmentfault.com/a/1190000014985174
转载请注明出处,Thanks♪(・ω・)ノ
ps:没有在swiper中添加scroll-view是为了可以使用页面的下拉刷新,最终方法直接跳到方案四。(含代码片段)
初始方案
swiper高度固定,swiper-item默认绝对定位且宽高100%,每个swiper-item中内容由固定高度的child组成,然后根据child数量动态计算swiper高度,初始方案(由于rpx针对屏幕宽度进行自适应,child_height使用rpx方便child正方形情况下自适应):swiper_height = child_height * child_num
屏幕效果仅在宽度375的设备(ip6、ipⅩ)完美契合,其他设备都底部会出现多余空隙,并且在上拉加载过程中,随着内容增加,底部空隙也逐渐变大。
方案二
开始以为是rpx适配显示问题,后通过文档中描述的WXSS 尺寸单位转化rpx为px(child_height使用rpx):swiper_height = child_height * child_num * ( window_width / 750 )
然后并无变化,我们可以看到child_height在不同宽度屏幕下,显示的宽高尺寸是不一样的(px单位),那就尝试使用box在各个屏幕的实际高度进行计算swiper高度,box的高度可以单独在页面中增加一个固定标签,该标签样式和box宽高保持一致并且隐藏起