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

首頁 > 編程 > JavaScript > 正文

js實現瀑布流的一種簡單方法實例分享

2019-11-20 21:47:42
字體:
來源:轉載
供稿:網友

下面奉上一則用JS實現瀑布流的方法,望批評。

復制代碼 代碼如下:

<!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>瀑布流布局測試</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;
    },

    // 是否滾動載入的檢測
    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;
    },

    // 滾動載入
    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;
    },

    // 頁面加載初始創建
    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是一個二維數組
                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) {
            // 新欄個數       
            this.columnNumber = Math.floor(document.body.clientWidth / this.columnWidth);

            // 計算每列的行數
            // 向下取整
            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];
                        }
                        // 是否補足余數
                        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;

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

    // 滾動加載
    scroll: function() {
        var self = this;
        window.onscroll = function() {
            // 為提高性能,滾動前后距離大于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) {
                // 檢測標簽偏移異常,認為布局要改變
                self.refresh();   
            }
        };
        return this;
    },
    init: function() {
        if (this.container) {
            this.create().scroll().resize();   
        }
    }
};
waterFall.init();
</script>
</body>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
红桃av永久久久| 亚洲视频精品在线| 久久久精品亚洲| 亚洲女人天堂成人av在线| 精品欧美激情精品一区| 成人伊人精品色xxxx视频| 亚洲女性裸体视频| 成人欧美一区二区三区在线| 欧美日韩在线视频首页| 一区二区欧美在线| 日本乱人伦a精品| 久久久影视精品| 国产精品成人久久久久| 亚洲激情自拍图| 国产自摸综合网| 亚洲人午夜精品| 午夜精品www| 亚洲黄色www网站| 成人网中文字幕| 日韩久久免费电影| 国产精品va在线播放我和闺蜜| 国产成人福利网站| 亚洲欧美制服第一页| 美女撒尿一区二区三区| 国产视频精品免费播放| 亚洲一区二区三区在线免费观看| 浅井舞香一区二区| 欧美一区二区三区免费观看| 国产视频在线观看一区二区| 中日韩午夜理伦电影免费| 亚洲女人天堂色在线7777| 中文字幕精品在线视频| 亚洲精品自在久久| 欧美丰满老妇厨房牲生活| 欧美精品www在线观看| 2021久久精品国产99国产精品| 久久国产一区二区三区| 一区二区三区视频观看| 国产精品免费网站| 欧美色欧美亚洲高清在线视频| 欧美一级片免费在线| 国产国语videosex另类| 亚洲天堂男人的天堂| 爽爽爽爽爽爽爽成人免费观看| 亚洲欧美日韩天堂一区二区| 国产免费一区二区三区在线能观看| 欧美性猛交xxxx免费看久久久| 亚洲成人三级在线| 热久久视久久精品18亚洲精品| 久久99热精品| 欧美视频不卡中文| 少妇精69xxtheporn| 欧美视频专区一二在线观看| 日本精品视频在线观看| 国产精品成熟老女人| 69av视频在线播放| 精品美女国产在线| 久久久久国色av免费观看性色| 欧美天天综合色影久久精品| 欧美性生活大片免费观看网址| 欧美猛少妇色xxxxx| 欧美噜噜久久久xxx| 亚洲韩国青草视频| 久久99精品久久久久久琪琪| 日韩中文字幕网站| 日韩精品久久久久久福利| 高清视频欧美一级| 最好看的2019年中文视频| 欧美超级乱淫片喷水| 国产日韩欧美综合| 亚洲综合自拍一区| 久久精品美女视频网站| 国产主播欧美精品| 国产精品久久久精品| 国内免费久久久久久久久久久| 国产视频观看一区| 国产精品久久色| 97碰碰碰免费色视频| 日韩高清电影免费观看完整版| 日本一区二区三区在线播放| 黑人狂躁日本妞一区二区三区| 日韩中文字幕免费视频| 欧美性猛交xxxx乱大交3| 2021久久精品国产99国产精品| 午夜精品一区二区三区在线播放| 亚洲护士老师的毛茸茸最新章节| 中文字幕在线观看亚洲| 亚洲国产精品va在线| 日韩在线观看网站| 在线免费观看羞羞视频一区二区| 亚洲成人久久久久| 国产欧美精品xxxx另类| 国内精品久久久久影院优| 国产在线精品播放| 黑人巨大精品欧美一区二区免费| 欧美激情视频网址| 另类美女黄大片| 久久久久久久爱| 中文字幕一区二区三区电影| 日韩在线观看高清| 91九色单男在线观看| 97人人爽人人喊人人模波多| 国产视频精品xxxx| 国产精品第10页| 国产九九精品视频| www.美女亚洲精品| 久久久精品美女| 97香蕉超级碰碰久久免费的优势| 亚洲欧美一区二区精品久久久| 38少妇精品导航| 久久精品99久久香蕉国产色戒| 日韩福利视频在线观看| 久久噜噜噜精品国产亚洲综合| 91沈先生在线观看| 97国产精品免费视频| 久久久欧美一区二区| 成人国产精品av| 日本一区二区在线播放| 国产欧美日韩中文| 色噜噜亚洲精品中文字幕| 亚洲国产小视频在线观看| 日韩欧美一区二区三区| 欧美性xxxx极品hd满灌| 国产一区二区三区直播精品电影| 亚洲精品在线视频| 成人激情视频免费在线| 97视频色精品| www高清在线视频日韩欧美| 国产极品jizzhd欧美| 国产精品成人一区二区| 在线激情影院一区| 亚洲а∨天堂久久精品9966| 欧美怡红院视频一区二区三区| 亚洲精品99久久久久| 亚洲精品98久久久久久中文字幕| 亚洲精品美女视频| 欧美制服第一页| 欧美成人精品在线视频| 在线观看国产精品淫| 国产精品日韩在线一区| 在线电影欧美日韩一区二区私密| 日韩欧美国产骚| 欧美高清性猛交| 国产成人短视频| 色樱桃影院亚洲精品影院| 国产亚洲精品美女久久久久| 欧美日韩精品在线观看| 欧美日韩国产中文字幕| 欧美日韩亚洲网| 国产精品日韩久久久久| 久久免费精品日本久久中文字幕| 日韩欧中文字幕| 国产一区二区三区精品久久久| 亚洲国产精品一区二区久| 欧美老女人性生活| 中文字幕日本欧美| 91免费看国产| 亚洲jizzjizz日本少妇| 日本aⅴ大伊香蕉精品视频| 日韩中文字幕在线观看| 国产丝袜一区二区| 国产精品视频在线播放| 亚洲一品av免费观看| 色yeye香蕉凹凸一区二区av|