成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

微信小程序下瀑布流加載解決方案

AlphaWatch / 1349人閱讀

摘要:實(shí)際效果如下這樣就實(shí)現(xiàn)了一個(gè)微信小程序下的瀑布流。實(shí)際效果可以打開微信,掃描左邊二維碼,直接體驗(yàn)?;蛘呶⑿判〕绦蛩阉髋恼沾笕?。

1、什么是瀑布流

1.1、瀑布流,又稱瀑布流式布局。是比較流行的一種網(wǎng)站頁面布局,圖片的寬度是固定的,高度自動(dòng)。視覺表現(xiàn)為參差不齊的多列布局,隨著頁面滾動(dòng)條向下滾動(dòng),這種布局還會(huì)不斷加載數(shù)據(jù)塊并附加至當(dāng)前尾部。

2、h5下實(shí)現(xiàn)一個(gè)瀑布流的基本思路 2.1、定義基本的html結(jié)構(gòu)

3.2、定義基本的wxss樣式

.content_list{position: relative;}
.list{width: 350rpx;min-height: 200rpx;}
.img_item{width: 100%;}

這里有個(gè)差別,就是我沒有給.list這個(gè)class設(shè)置padding了,因?yàn)樵谖⑿判〕绦蛳率遣荒軌虿僮鞴?jié)點(diǎn)獲取樣式的。
后面我們將根據(jù)圖片的寬度動(dòng)態(tài)計(jì)算左右兩邊以及左邊一列圖片的padding。同時(shí)這里圖片的單位用的是rpx。主要是為了適應(yīng)不同屏幕終端。
3.3、js動(dòng)態(tài)計(jì)算加載項(xiàng)的樣式。
兩種方案,第一種定義一個(gè)隱藏域,用于存放圖片,當(dāng)圖片加載的時(shí)候綁定加載事件獲取圖片的寬高

    
        
    

主要js代碼如下:

onImageLoad: function (e) {
        let imageId = e.currentTarget.id;
        let oImgW = e.detail.width;         //圖片原始寬度
        let oImgH = e.detail.height;        //圖片原始高度
        let imgWidth = (this.data.winWidth - 20) * 0.48;
        let scale = imgWidth / oImgW;        //比例計(jì)算
        let imgHeight = scale * oImgH;
        let imgObj = {
            id: imageId,
            width: imgWidth,
            height: imgHeight
        };
        imgLen++;
        for (let i = 0; i < temResImgArr.length; i++) {
            if (temResImgArr[i].id == imageId) {
                temResImgArr[i].width = imgWidth;
                temResImgArr[i].height = imgHeight;
                break;
            }
        }
        if (imgLen == temResImgArr.length) {//圖片遍歷完
            this.waterFall();
        }

    },
    onImageError: function (e) {
        imgLen++;
    },
     waterFall: function () {
        for (let i = 0; i < temResImgArr.length; i++) {
            if (heightArr.length < 2 && i < 2) {
                heightArr.push(temResImgArr[i].height + 10);
            } else {
                let minH = Math.min.apply(null, heightArr);
                let index = heightArr.indexOf(minH);
                temResImgArr[i].top = `${minH}`;
                temResImgArr[i].left = `${360 * index}rpx`;
                heightArr[index] += (temResImgArr[i].height + 10);
            }
        }
        let maxH = Math.max.apply(null, heightArr);
        let temp = this.data.imgArr;
        temp.push(...temResImgArr);
        this.setData({
            imgArr: temp,
            viewHeight: maxH,
            temImgArr: []
        });
        //重置數(shù)據(jù)。
        temResImgArr = [];
        imgLen = 0;
        wx.hideToast();
    },

但是這種方案并不是最優(yōu),需要定義2個(gè)臨時(shí)數(shù)組來處理加載的圖片,同時(shí)用戶等待的時(shí)間太長,必須要等所有圖片加載完后獲取到所有的高度后才能夠展示出來,體驗(yàn)很不好。
既然花了大部分時(shí)間在獲取圖片寬高上面,那么為什么不能夠從接口輸出圖片寬高呢?
所以要么上傳圖片的時(shí)候把寬高錄入db,但是這種并沒有什么意義。要么就是輸出的時(shí)候處理,這時(shí)想到了PHP有個(gè)getimagesize函數(shù)(PHP是世界上最好的語言有木有),可以獲取到圖片的寬高。這樣就不用改db了。
備注:這里更正下,組內(nèi)大神一眼就看出輸出時(shí)候用getimagesize函數(shù)處理存在性能問題,就是高并發(fā)的時(shí)候、服務(wù)器帶寬很容易耗盡,不同進(jìn)程之間拉取同樣圖片還無法利用緩存。最后還是改為將圖片寬高存入后臺(tái)。
且看改進(jìn)后的js代碼:

 onLoad: function () {
        let self = this;
        imgLen = 0;
        heightArr = [];
        wx.getSystemInfo({
            success: function (res) {
                let imgW = Math.floor(350 * (res.windowWidth) / 750);//圖片在當(dāng)前屏幕尺寸下的實(shí)際寬度
                let colW = Math.floor((res.windowWidth - 2 * imgW) / 3);//左右兩邊邊距和圖片邊距的寬度
                self.setData({
                    winWidth: res.windowWidth,
                    winHeight: res.windowHeight,
                    colW: colW,
                });
                self.getImgInfo();
            }
        })
    },
waterFall: function (data) {
        let j = 0;
        for (let i = 0; i < data.length; i++) {//遍歷動(dòng)態(tài)加載的數(shù)據(jù)
            let imgW = Math.floor(350 * this.data.winWidth / 750);//獲取圖片在當(dāng)前屏幕下的實(shí)際寬度
            data[i].height = Math.floor(imgW * data[i].height / data[i].width);
            if (heightArr.length < 2 && i < 2) {
                heightArr.push(data[i].height + this.data.colW);//實(shí)際高度+動(dòng)態(tài)邊距
                data[i].top = `0`;
                data[i].left = i == 0 ? `${imgW * i + this.data.colW}` : `${imgW * i + 2 * this.data.colW}`;
            } else {
                let minH = Math.min.apply(null, heightArr);
                let index = heightArr.indexOf(minH);
                data[i].top = `${minH}`;
                data[i].left = index == 0 ? `${imgW * index + this.data.colW}` : `${imgW * index + 2 * this.data.colW}`;
                heightArr[index] += (data[i].height + this.data.colW);
            }
        }
        let maxH = Math.max.apply(null, heightArr);
        let temp = this.data.imgArr;
        temp.push(...data);//追加到當(dāng)前圖片列表中
        this.setData({
            imgArr: temp,
            viewHeight: maxH,
        });
        //重置數(shù)據(jù)。
        temp=null;
        imgLen = 0;
        wx.hideToast();
    },

實(shí)際效果如下:

這樣就實(shí)現(xiàn)了一個(gè)微信小程序下的瀑布流。實(shí)際效果可以打開微信,掃描左邊二維碼,直接體驗(yàn)。或者微信小程序搜索拍照POSE大全。里面附很多美圖,各種拍照姿勢等你來完善,來補(bǔ)充,歡迎體驗(yàn)并上傳自己的小姿勢。
PS:無雙不成對,一張圖太單調(diào),請容許我再附上最近做的一款美的砍價(jià)小程序,美的認(rèn)證,砍到即可購買。最近天氣熱,有購買家電的朋友可以掃碼購買。

最后,如果你有更優(yōu)的解決方案請告訴我,我們一起探討,歡迎點(diǎn)評!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/25559.html

相關(guān)文章

  • 信小程序瀑布加載解決方案

    摘要:實(shí)際效果如下這樣就實(shí)現(xiàn)了一個(gè)微信小程序下的瀑布流。實(shí)際效果可以打開微信,掃描左邊二維碼,直接體驗(yàn)。或者微信小程序搜索拍照大全。 1、什么是瀑布流 1.1、瀑布流,又稱瀑布流式布局。是比較流行的一種網(wǎng)站頁面布局,圖片的寬度是固定的,高度自動(dòng)。視覺表現(xiàn)為參差不齊的多列布局,隨著頁面滾動(dòng)條向下滾動(dòng),這種布局還會(huì)不斷加載數(shù)據(jù)塊并附加至當(dāng)前尾部。 2、h5下實(shí)現(xiàn)一個(gè)瀑布流的基本思路 2.1、定義...

    kumfo 評論0 收藏0
  • 原生js實(shí)現(xiàn)瀑布信小程序中使用左右兩列實(shí)現(xiàn)瀑布

    摘要:使用實(shí)現(xiàn)瀑布流并不實(shí)用,因?yàn)閷?shí)現(xiàn)的瀑布流都是以列來排列的,這里記錄下用實(shí)現(xiàn)瀑布流,以及微信小程序中使用左右兩列來實(shí)現(xiàn)瀑布流效果圖原生實(shí)現(xiàn)瀑布流文件圖片可以自己找點(diǎn)替換下就可以了文件添加陰影的時(shí)候,加上會(huì)顯得更加有點(diǎn)懸浮感文件計(jì)算圖片列數(shù) 使用css實(shí)現(xiàn)瀑布流并不實(shí)用,因?yàn)閏ss實(shí)現(xiàn)的瀑布流都是以列來排列的,這里記錄下用js實(shí)現(xiàn)瀑布流,以及微信小程序中使用左右兩列來實(shí)現(xiàn)瀑布流 1.效果圖...

    imingyu 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<