亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

小程序瀑布流解決左右兩邊高度差距過大的問題

2024-09-05 07:22:49
字體:
來源:轉載
供稿:網友

想要實現瀑布流的布局效果,并且是按照從左到右順序顯示的話,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測量兩欄的高度,得出高度差。

這種方法則必須在圖片加載完,再測量某個元素是否需要移動,元素移動會比較明顯。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久在线播放| 精品一区二区三区四区在线| 96精品久久久久中文字幕| 亚洲影院色在线观看免费| 亚洲女同精品视频| 久久99亚洲精品| 一区二区三区四区精品| 自拍偷拍亚洲一区| 懂色av一区二区三区| 日韩欧美精品网站| 在线播放日韩精品| 亚洲最大的网站| 亚洲精品国产成人| 2019亚洲日韩新视频| 日韩在线观看网址| 亚洲综合国产精品| 欧美精品一区二区三区国产精品| 亚洲自拍偷拍区| 91精品国产91| 成人网在线视频| 欧美激情va永久在线播放| 久久精品国产一区二区三区| 国产日韩在线观看av| 国产精品日韩欧美大师| 亚洲偷熟乱区亚洲香蕉av| 国产成人免费av电影| 成人免费视频97| 国外成人在线视频| 欧美自拍视频在线| 日本伊人精品一区二区三区介绍| 日韩女优人人人人射在线视频| 在线观看欧美日韩| 中文字幕欧美国内| 亚洲一区二区三区视频播放| 国产美女搞久久| 深夜福利亚洲导航| 久久人人爽人人爽人人片亚洲| 51午夜精品视频| 亚洲视频自拍偷拍| 亚洲成人激情在线观看| 国产亚洲激情视频在线| 亚洲综合色激情五月| 精品视频一区在线视频| 久久精品这里热有精品| 欧美日韩综合视频网址| 欧美日韩国产专区| 国产精品第3页| 色偷偷88888欧美精品久久久| 久久精品国产一区| 亚洲日本aⅴ片在线观看香蕉| 日韩美女视频中文字幕| 精品在线小视频| 亚洲精品欧美极品| 麻豆一区二区在线观看| 亚洲成色777777在线观看影院| 国产精品99久久久久久久久久久久| 成人黄色在线观看| 国产精品第一第二| 国产亚洲精品久久久久久| 日本中文字幕不卡免费| 亚洲xxxx做受欧美| 26uuu另类亚洲欧美日本一| 欧美电影免费观看电视剧大全| 亚洲国产成人在线播放| 热久久99这里有精品| 亚洲精品福利在线观看| 亚洲aaaaaa| 欧美成人免费全部观看天天性色| 欧美激情一区二区三区久久久| 狠狠综合久久av一区二区小说| 亚洲第五色综合网| 韩日欧美一区二区| 亚洲成成品网站| 性欧美长视频免费观看不卡| 色综合伊人色综合网站| 成人妇女免费播放久久久| 亚洲欧洲第一视频| 亚洲自拍偷拍福利| 欧美电影在线免费观看网站| 国产成人极品视频| 欧美诱惑福利视频| 国产精品久久色| 狠狠久久五月精品中文字幕| 中文字幕亚洲欧美一区二区三区| 成人激情在线观看| 精品国产一区二区三区四区在线观看| 欧美精品videofree1080p| 国产欧美精品久久久| 午夜精品视频网站| 国产日本欧美在线观看| 亚洲黄色av网站| 欧美制服第一页| 久热精品视频在线观看| 亚洲 日韩 国产第一| 亚洲黄色免费三级| 国产日韩在线看片| 国产一区二区黄| 欧美日韩亚洲高清| 日韩av在线不卡| 中文字幕综合在线| 亚洲аv电影天堂网| 国产欧美日韩精品在线观看| 九色精品免费永久在线| 欧美大片大片在线播放| 亚洲午夜未删减在线观看| 亚洲第一男人天堂| 亚洲第一综合天堂另类专| 亚洲第一国产精品| 国产精品高潮呻吟久久av黑人| 欧美精品在线免费观看| 国产精品一区=区| 亚洲一区二区三| 中文字幕亚洲二区| 亚洲美女在线视频| 亚洲91av视频| 国产精品第一第二| 国产精品视频一区二区高潮| x99av成人免费| 国产精品小说在线| 久久久久国产精品一区| 久久精品91久久久久久再现| 久久97久久97精品免视看| 最近2019中文免费高清视频观看www99| 欧美香蕉大胸在线视频观看| 色综合91久久精品中文字幕| 亚洲欧美国产一区二区三区| 国产一区二区三区高清在线观看| 国产999精品视频| 欧美丰满少妇xxxxx做受| 久久精品久久久久久国产 免费| 久久网福利资源网站| 超在线视频97| 日韩精品视频在线观看网址| 亚洲黄色av网站| 91大神在线播放精品| 日韩一二三在线视频播| 日韩av电影中文字幕| 亚洲欧洲在线视频| 欧美精品九九久久| 欧美一级电影在线| 亚洲无av在线中文字幕| 久久久天堂国产精品女人| 欧美午夜激情在线| 日韩电影中文字幕在线观看| 日韩美女免费视频| 91精品久久久久| 欧美日韩福利电影| 九九九热精品免费视频观看网站| 一区二区国产精品视频| 国产精品无码专区在线观看| 亚洲性猛交xxxxwww| www.欧美三级电影.com| 亚洲福利视频专区| 日韩在线中文字| 亚洲精品免费一区二区三区| 欧美猛少妇色xxxxx| 国产精品高清免费在线观看| 国产成人精品日本亚洲| 日韩欧美中文免费| 国产丝袜一区视频在线观看| 日本成熟性欧美| 在线精品视频视频中文字幕| 神马久久久久久| 国产亚洲精品久久久久久|