国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序實現瀑布流布局與無限加載的方法詳解

2019-11-19 16:35:57
字體:
來源:轉載
供稿:網友

前言

瀑布流布局是一種比較流行的頁面布局方式,最典型的就是Pinterest.com,每個卡片的高度不都一樣,形成一種參差不齊的美感。

在HTML5中,我們可以找到很多基于jQuery之類實現的瀑布流布局插件,輕松做出這樣的布局形式。在微信小程序中,我們也可以做出這樣的效果,不過由于小程序框架的一些特性,在實現思路上還是有一些差別的。

今天我們就來看一下如何在小程序中去實現這種瀑布流布局:


小程序瀑布流布局

我們要實現的是一個固定2列的布局,然后將圖片數據動態加載進這兩列中(而加載進來的圖片,會根據圖片實際的尺寸,來決定到底是放在左列還是右列中)。

/* 單個圖片容器的樣式 */.img_item { width: 48%; margin: 1%; display: inline-block; vertical-align: top;}

我們知道,在HTML中,我們要動態加載圖片的話,通常會使用new Image()創建一個圖片對象,然后通過它來動態加載一個url指向的圖片,并獲取圖片的實際尺寸等信息。而在小程序框架中,并沒有提供相應的JS對象來處理圖片加載。其實我們可以借助wxml中的<image>組件來完成這樣的功能,雖然有點繞,但還是能滿足我們的功能要求的。

<!-- 在頁面上放一個隱藏區域,并用image組件去加載一個或多個圖片資源 --><view style="display:none"> <image wx:for="{{images}}" wx:key="id" id="{{item.id}}" src="{{item.pic}}" bindload="onImageLoad"></image></view>

我們可以在Page中通過數據綁定,來傳遞要加載的圖片信息到wxml中,讓<image>組件去加載圖片資源,然后當圖片加載完成的時候,通過bindload指定的事件處理函數來做進一步處理。

我們來看一下Page文件中定義的onImageLoad函數。在其中,我們可以從傳入的事件對象e上,獲取到<image>組件的豐富信息,包括通過它加載進來的圖片的實際大小。然后我們將圖片按照頁面上實際需要顯示的尺寸,計算出同比例縮放后的尺寸。接著,我們可以根據左右兩列目前累積的內容高度,來決定把當前加載進來的圖片放到哪一邊。

let col1H = 0;let col2H = 0;Page({ data: {  scrollH: 0,  imgWidth: 0,  loadingCount: 0,  images: [],  col1: [],  col2: [] }, onLoad: function () {  wx.getSystemInfo({   success: (res) => {    let ww = res.windowWidth;    let wh = res.windowHeight;    let imgWidth = ww * 0.48;    let scrollH = wh;    this.setData({     scrollH: scrollH,     imgWidth: imgWidth    });    //加載首組圖片    this.loadImages();   }  }) }, onImageLoad: function (e) {  let imageId = e.currentTarget.id;  let oImgW = e.detail.width;   //圖片原始寬度  let oImgH = e.detail.height;  //圖片原始高度  let imgWidth = this.data.imgWidth; //圖片設置的寬度  let scale = imgWidth / oImgW;  //比例計算  let imgHeight = oImgH * scale;  //自適應高度  let images = this.data.images;  let imageObj = null;  for (let i = 0; i < images.length; i++) {   let img = images[i];   if (img.id === imageId) {    imageObj = img;    break;   }  }  imageObj.height = imgHeight;  let loadingCount = this.data.loadingCount - 1;  let col1 = this.data.col1;  let col2 = this.data.col2;  //判斷當前圖片添加到左列還是右列  if (col1H <= col2H) {   col1H += imgHeight;   col1.push(imageObj);  } else {   col2H += imgHeight;   col2.push(imageObj);  }  let data = {   loadingCount: loadingCount,   col1: col1,   col2: col2  };  //當前這組圖片已加載完畢,則清空圖片臨時加載區域的內容  if (!loadingCount) {   data.images = [];  }  this.setData(data); }, loadImages: function () {  let images = [   { pic: "../../images/1.png", height: 0 },   { pic: "../../images/2.png", height: 0 },   { pic: "../../images/3.png", height: 0 },   { pic: "../../images/4.png", height: 0 },   { pic: "../../images/5.png", height: 0 },   { pic: "../../images/6.png", height: 0 },   { pic: "../../images/7.png", height: 0 },   { pic: "../../images/8.png", height: 0 },   { pic: "../../images/9.png", height: 0 },   { pic: "../../images/10.png", height: 0 },   { pic: "../../images/11.png", height: 0 },   { pic: "../../images/12.png", height: 0 },   { pic: "../../images/13.png", height: 0 },   { pic: "../../images/14.png", height: 0 }  ];  let baseId = "img-" + (+new Date());  for (let i = 0; i < images.length; i++) {   images[i].id = baseId + "-" + i;  }  this.setData({   loadingCount: images.length,   images: images  }); }})

這里是顯示在兩列圖片的wxml代碼,我們可以看到在<scroll-view>組件上,我們通過使用bindscrolltolower設置了事件監聽函數,當滾動到底部的時候,會觸發loadImages去再加載下一組的圖片數據,這樣就形成了無限的加載:

<scroll-view scroll-y="true" style="height:{{scrollH}}px" bindscrolltolower="loadImages"> <view style="width:100%"> <view class="img_item">  <view wx:for="{{col1}}" wx:key="id">  <image src="{{item.pic}}" style="width:100%;height:{{item.height}}px"></image>  </view> </view> <view class="img_item">  <view wx:for="{{col2}}" wx:key="id">  <image src="{{item.pic}}" style="width:100%;height:{{item.height}}px"></image>  </view> </view> </view></scroll-view>

好了,挺簡單的一個例子,如果你有更好的方法,不吝分享一下哦。

完整代碼可以在Github下載:https://github.com/zarknight/wx-falls-layout  也可以通過本地進行下載

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新宁县| 庆元县| 吉安市| 土默特右旗| 西林县| 沈丘县| 盘锦市| 昭平县| 凤翔县| 宁陕县| 黔江区| 宜春市| 泗水县| 辽阳县| 永福县| 普陀区| 贺兰县| 惠来县| 河北省| 云梦县| 鄂温| 仪征市| 沅江市| 卓尼县| 海丰县| 方山县| 屏南县| 怀柔区| 孟连| 绩溪县| 喀喇沁旗| 徐汇区| 元阳县| 内乡县| 兴国县| 武汉市| 东台市| 砀山县| 玉山县| 兴化市| 抚顺县|