麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > JavaScript > 正文

js實(shí)現(xiàn)瀑布流的一種簡(jiǎn)單方法實(shí)例分享

2019-11-20 21:47:42
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

下面奉上一則用JS實(shí)現(xiàn)瀑布流的方法,望批評(píng)。

復(fù)制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>瀑布流布局測(cè)試</title>
<style>
body {
    background-color: #eee;
    font-size: 84%;
    text-align: justify;
}
.column {
    display: inline-block;
    vertical-align: top;
}
.pic_a {
    display: block;
    padding: 5px;
    margin-bottom: 10px;
    border: 1px solid #ccc;
    background-color: #fff;
    text-decoration: none;
}
.pic_a img {
    display: block;
    margin: 0 auto 5px;
    border: 0;
    vertical-align: bottom;
}
.pic_a strong {
    color: #333;
}
</style>
</head>

<body>
<div id="container"></div>
<script>
var waterFall = {
    container: document.getElementById("container"),
    columnNumber: 1,
    columnWidth: 210,
    // P_001.jpg ~ P_160.jpg
    rootImage: "test/",
    indexImage: 0,

    scrollTop: document.documentElement.scrollTop || document.body.scrollTop,
    detectLeft: 0,

    loadFinish: false,

    // 返回固定格式的圖片名
    getIndex: function() {
        var index = this.indexImage;
        if (index < 10) {
            index = "00" + index;   
        } else if (index < 100) {
            index = "0" + index;   
        }
        return index;
    },

    // 是否滾動(dòng)載入的檢測(cè)
    appendDetect: function() {
        var start = 0;
        for (start; start < this.columnNumber; start++) {
            var eleColumn = document.getElementById("waterFallColumn_" + start);
            if (eleColumn && !this.loadFinish) {
                if (eleColumn.offsetTop + eleColumn.clientHeight < this.scrollTop + (window.innerHeight || document.documentElement.clientHeight)) {
                    this.append(eleColumn);
                }
            }           
        }

        return this;
    },

    // 滾動(dòng)載入
    append: function(column) {
        this.indexImage += 1;
        var html = '', index = this.getIndex(), imgUrl = this.rootImage + "P_" + index + ".jpg";

        // 圖片尺寸
        var aEle = document.createElement("a");
        aEle.href = "###";
        aEle.className = "pic_a";
        aEle.innerHTML = '<img src="'+ imgUrl +'" /><strong>'+ index +'</strong>';
        column.appendChild(aEle);

        if (index >= 160) {
            //alert("圖片加載光光了!");
            this.loadFinish = true;
        }

        return this;
    },

    // 頁(yè)面加載初始創(chuàng)建
    create: function() {
        this.columnNumber = Math.floor(document.body.clientWidth / this.columnWidth);

        var start = 0, htmlColumn = '', self = this;
        for (start; start < this.columnNumber; start+=1) {
            htmlColumn = htmlColumn + '<span id="waterFallColumn_'+ start +'" class="column" style="width:'+ this.columnWidth +'px;">'+
                function() {
                    var html = '', i = 0;
                    for (i=0; i<5; i+=1) {
                        self.indexImage = start + self.columnNumber * i;
                        var index = self.getIndex();
                        html = html + '<a href="###" class="pic_a"><img src="'+ self.rootImage + "P_" + index +'.jpg" /><strong>'+ index +'</strong></a>';
                    }
                    return html;   
                }() +
            '</span> ';   
        }
        htmlColumn += '<span id="waterFallDetect" class="column" style="width:'+ this.columnWidth +'px;"></span>';

        this.container.innerHTML = htmlColumn;

        this.detectLeft = document.getElementById("waterFallDetect").offsetLeft;
        return this;
    },

    refresh: function() {
        var arrHtml = [], arrTemp = [], htmlAll = '', start = 0, maxLength = 0;
        for (start; start < this.columnNumber; start+=1) {
            var arrColumn = document.getElementById("waterFallColumn_" + start).innerHTML.match(/<a(?:.|/n|/r|/s)*?a>/gi);
            if (arrColumn) {
                maxLength = Math.max(maxLength, arrColumn.length);
                // arrTemp是一個(gè)二維數(shù)組
                arrTemp.push(arrColumn);
            }
        }

        // 需要重新排序
        var lengthStart, arrStart;
        for (lengthStart = 0; lengthStart<maxLength; lengthStart++) {
            for (arrStart = 0; arrStart<this.columnNumber; arrStart++) {
                if (arrTemp[arrStart][lengthStart]) {
                    arrHtml.push(arrTemp[arrStart][lengthStart]);   
                }
            }   
        }

       
        if (arrHtml && arrHtml.length !== 0) {
            // 新欄個(gè)數(shù)       
            this.columnNumber = Math.floor(document.body.clientWidth / this.columnWidth);

            // 計(jì)算每列的行數(shù)
            // 向下取整
            var line = Math.floor(arrHtml.length / this.columnNumber);

            // 重新組裝HTML
            var newStart = 0, htmlColumn = '', self = this;
            for (newStart; newStart < this.columnNumber; newStart+=1) {
                htmlColumn = htmlColumn + '<span id="waterFallColumn_'+ newStart +'" class="column" style="width:'+ this.columnWidth +'px;">'+
                    function() {
                        var html = '', i = 0;
                        for (i=0; i<line; i+=1) {
                            html += arrHtml[newStart + self.columnNumber * i];
                        }
                        // 是否補(bǔ)足余數(shù)
                        html = html + (arrHtml[newStart + self.columnNumber * line] || '');

                        return html;   
                    }() +
                '</span> ';   
            }
            htmlColumn += '<span id="waterFallDetect" class="column" style="width:'+ this.columnWidth +'px;"></span>';

            this.container.innerHTML = htmlColumn;

            this.detectLeft = document.getElementById("waterFallDetect").offsetLeft;

            // 檢測(cè)
            this.appendDetect();
        }
        return this;
    },

    // 滾動(dòng)加載
    scroll: function() {
        var self = this;
        window.onscroll = function() {
            // 為提高性能,滾動(dòng)前后距離大于100像素再處理
            var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
            if (!this.loadFinish && Math.abs(scrollTop - self.scrollTop) > 100) {
                self.scrollTop = scrollTop;
                self.appendDetect();   
            }

        };
        return this;
    },

    // 瀏覽器窗口大小變換
    resize: function() {
        var self = this;
        window.onresize = function() {
            var eleDetect = document.getElementById("waterFallDetect"), detectLeft = eleDetect && eleDetect.offsetLeft;
            if (detectLeft && Math.abs(detectLeft - self.detectLeft) > 50) {
                // 檢測(cè)標(biāo)簽偏移異常,認(rèn)為布局要改變
                self.refresh();   
            }
        };
        return this;
    },
    init: function() {
        if (this.container) {
            this.create().scroll().resize();   
        }
    }
};
waterFall.init();
</script>
</body>
</html>

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产亚洲精品久久久久久网站 | 久久精品国产久精国产 | 97香蕉超级碰碰久久免费软件 | hd porn 4k video xhicial| 毛片免费观看视频 | 欧美中文字幕一区二区三区亚洲 | 亚洲精品一区国产精品丝瓜 | 法国极品成人h版 | 一级做a爱视频 | 99麻豆久久久国产精品免费 | 成年性羞羞视频免费观看 | 久久久久久久久久久国产精品 | av在线直播观看 | 成人免费精品视频 | 91在线视频在线观看 | 黄色片一区二区 | 欧美日韩国产成人在线观看 | av在线影片 | 日韩一级电影在线观看 | 精品一区二区久久久久久久网精 | 99热99精品 | 最新久久免费视频 | 国产1区2 | 日韩精品二区 | 国产中出视频 | 亚洲码无人客一区二区三区 | 91av亚洲| 久久国产精品久久精品国产演员表 | 欧美精品成人一区二区三区四区 | 精品一区二区久久久久久久网精 | 综合精品一区 | 精品国产乱码久久久久久久 | 久久精品一区二区三区四区五区 | 久久超碰99 | 成年人黄色片视频 | 精品国产一区二区三区四 | 亚洲国产精品一区二区精品 | 九一免费国产 | 久久草草影视免费网 | 久章草在线观看 | 国产亚洲欧美日韩在线观看不卡 |