小程序scroll-view自适应高度(小程序瀑布流解决左右两边高度差距过大的问题)
小程序scroll-view自适应高度
小程序瀑布流解决左右两边高度差距过大的问题想要实现瀑布流的布局效果,并且是按照从左到右顺序显示的话,css布局方式暂时还不能满足我们的需求。参考小红书的瀑布流效果,小红书是分左右两栏的,按照奇数偶数来显示就可以。
<view class="waterfall"> <view class="waterfall-left"> <view wx:if="{{index%2 == 0}}" class="item"></view> </view> <view class="waterfall-right"> <view wx:if="{{index%2 == 1}}" class="item"></view> </view> </view>
但是问题来了,随着每个元素高度的不确定性,很大几率会出现左右两栏高度相差大的问题。
解决方法:
要解决这个问题,我们要找出导致每个元素的高度不同的原因,一般是图片的高度,也可能是根据条件显示的某些区域,建议只有图片的高度不同,其它部分的高度保持不变,这会使得我们的计算变得简单。
大概思路,取得左右两栏的高度,计算左右两栏的高请输入代码度差值,移动两栏差值threshold
的2分之1,如图:
上面是理想的状态,但是我们不可能切开元素,我们要知道高度高的一边的是否有符合移动的元素,如果高度高的那栏中高度最小的元素minH
小于 差值threshold
,那么我们可以移动,可以取长边某个与差值的二分之一高度最接近的一个元素minH
(一般是高度最小的那个,也可以取巧地移动高度最小的一个)。如果高度最小的元素比差值还大,则不需要移动。
那么怎么移动,默认给元素一个属性position,值为center,如果该元素要移动到左边,那么给该元素一个属性:position:left;优先根据position属性来显示,其次才根据奇数偶数来显示,如下:
<view class="waterfall"> <view class="waterfall-left"> <view wx:if="{{item.position=='left' || (index%2 == 0&&item.position=='center')}}" class="item"></view> </view> <view class="waterfall-right"> <view wx:if="{{item.position=='right' || (index%2 == 1&&item.position=='center')}}" class="item"></view> </view> </view>
至此,高度相差较大的问题就可以解决了。
我们如何计算两栏的高度呢?
重点是获取图片的宽高,我们就可以知道两栏的高度,这里分两种情况:
1. 接口返回图片的宽高
接口返回了图片的宽高,那么我们直接累加图片的高度,就可以比较两栏的高度,得出高度差。
如果较高的一边的minH
比两栏高度的差值threshold
小,即minH < threshold
,那么minH
就需要移动
这种方式在拿到数据的同时,我们就可以知道某个元素是否需要移动。处理完数据后马上渲染到视图层。
这种方法当然是最省心的,但是接口也有可能不返回图片的宽高,于是就要用第2种方法了。
2. 接口不返回图片的宽高,在图片load事件取得图片宽高
监听图片的load事件,获得图片的宽高,在最后一张图片load完之后,用boundingClientRect测量两栏的高度,得出高度差。
这种方法则必须在图片加载完,再测量某个元素是否需要移动,元素移动会比较明显。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
- flask项目微信小程序(Python Flask 搭建微信小程序后台详解)
- 微信小程序计时器(微信小程序实现简单的计算器功能)
- wx小程序请求封装(小程序wx.getUserProfile接口的具体使用)
- 9小时搞定微信小程序开发(关于加快微信小程序开发的一些小建议)
- 微信小程序即时聊天功能怎么实现(微信小程序实现聊天室功能)
- 小程序实现购物车功能前后端代码(小程序实现购物车完整版)
- 微信小程序单选框组件(微信小程序picker多列选择器mode = multiSelector)
- 微信小程序引用模板的函数(微信小程序页面与组件之间信息传递与函数调用)
- 微信小程序存token(小程序开发实现access_token统一管理)
- 微信小程序静态页面详情(微信小程序基础教程之echart的使用)
- dedecms织梦小程序插件(批量删除织梦dedecms文档搜索关键词的方法)
- html5带图标下拉菜单(html5小程序飞入购物车抛物线绘制运动轨迹点)
- 微信小程序计算器怎么用(微信小程序实现计算器功能)
- 微信小程序开发完整操作流程(微信小程序开发之组件设计规范)
- 微信小程序双人游戏横屏(微信小程序实现拼图游戏)
- 用python制作一个简单的小程序(一个可以套路别人的python小程序实例代码)
- 刘韬涛丁子贺小品《根治低头族》台词剧本(刘韬涛丁子贺小品根治低头族台词剧本)
- 看完《夺冠》,黄渤的演技我实在夸不起来,彭昱畅反令人惊喜(黄渤的演技我实在夸不起来)
- 黄渤泪目 我的痴呆父亲,我内心永远的痛(黄渤泪目我的痴呆父亲)
- 蒜苔和鱿鱼尾巴一起炒,味道特别棒,又脆又嫩,有滋又有味(蒜苔和鱿鱼尾巴一起炒)
- 鱿鱼炒蒜苔不是黑暗料理,这样做清香扑鼻,鲜美脆嫩,开胃又下饭(鱿鱼炒蒜苔不是黑暗料理)
- 蒜苔炒鱿鱼(蒜苔炒鱿鱼)
热门推荐
- 正则表达式在python的中的应用(Python中正则表达式的用法总结)
- dockerfile深度解析(Dockerfile文本文件使用方法实例解析)
- pythonredis使用场景(python redis 删除key脚本的实例)
- php如何发邮件(PHP示例演示发送邮件给某个邮箱)
- css !important的用法
- 云主机免费推荐吗(云主机可以永久免费吗?)
- python mongodb 基本操作(Python使用pymongo库操作MongoDB数据库的方法实例)
- python微信窗口内容获取(python使用wxpy轻松实现微信防撤回的方法)
- typescript使用技巧(深入理解typescript中的infer关键字的使用)
- web前端测试工具