婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 3種方式實現瀑布流布局小結

3種方式實現瀑布流布局小結

熱門標簽:電話機器人技術 ok電銷機器人 高德地圖標注商戶怎么標 欣鼎電銷機器人 效果 惡搞電話機器人 地圖標注軟件打印出來 如何查看地圖標注 智能電銷機器人被禁用了么 黃石ai電銷機器人呼叫中心

前言

今天逛閑魚的時候觀察到每一行的高度不是相同的,經了解才知道原來這是一種瀑布流布局,感覺挺有意思,于是決定研究一下,在網上也找了一些方案,實現瀑布流大概有3種方式。

一、JS 實現瀑布流

思路分析

  • 瀑布流布局的特點是等寬不等高。
  • 為了讓最后一行的差距最小,從第二行開始,需要將圖片放在第一行最矮的圖片下面,以此類推。
  • 父元素設置為相對定位,圖片所在元素設置為絕對定位。然后通過設置 top 值和 left 值定位每個元素。

代碼實現

<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            width: 100%;
            position:relative;
        }
        .item {
            position: absolute;
        }
        .item img{
            width: 100%;
            height:100%;
        }
    </style>
</head>
<body>
<div class="box">
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
</div>
</body>
<script src="jquery.min.js"></script>
<script>
    function waterFall() {
        // 1 確定圖片的寬度 - 滾動條寬度
        var pageWidth = getClient().width-8;
        var columns = 3; //3列
        var itemWidth = parseInt(pageWidth/columns); //得到item的寬度
        $(".item").width(itemWidth); //設置到item的寬度
        var arr = [];
        $(".box .item").each(function(i){
            var height = $(this).find("img").height();
            if (i < columns) {
                // 2 第一行按序布局
                $(this).css({
                    top:0,
                    left:(itemWidth) * i+20*i,
                });
                //將行高push到數組
                arr.push(height);
            } else {
                // 其他行
                // 3 找到數組中最小高度  和 它的索引
                var minHeight = arr[0];
                var index = 0;
                for (var j = 0; j < arr.length; j++) {
                    if (minHeight > arr[j]) {
                        minHeight = arr[j];
                        index = j;
                    }
                }
                // 4 設置下一行的第一個盒子位置
                // top值就是最小列的高度
                $(this).css({
                    top:arr[index]+30,//設置30的距離
                    left:$(".box .item").eq(index).css("left")
                });

                // 5 修改最小列的高度
                // 最小列的高度 = 當前自己的高度 + 拼接過來的高度
                arr[index] = arr[index] + height+30;//設置30的距離
            }
        });
    }
    //clientWidth 處理兼容性
    function getClient() {
        return {
            width: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth,
            height: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight
        }
    }
    // 頁面尺寸改變時實時觸發
    window.onresize = function() {
        //重新定義瀑布流
        waterFall();
    };
    //初始化
    window.onload = function(){
        //實現瀑布流
        waterFall();
    }
</script>
</html>

效果如下
 

二、column 多行布局實現瀑布流

思路分析:

column 實現瀑布流主要依賴兩個屬性。
一個是 column-count 屬性,是分為多少列。
一個是 column-gap 屬性,是設置列與列之間的距離。

代碼實現:

<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            margin: 10px;
            column-count: 3;
            column-gap: 10px;
        }
        .item {
            margin-bottom: 10px;
        }
        .item img{
            width: 100%;
            height:100%;
        }
    </style>
</head>
<body>
<div class="box">
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
</div>
</body>

效果如下:
 

三、flex 彈性布局實現瀑布流

思路分析:

flex 實現瀑布流需要將最外層元素設置為 display: flex,即橫向排列。然后通過設置 flex-flow:column wrap 使其換行。設置 height: 100vh 填充屏幕的高度,來容納子元素。每一列的寬度可用 calc 函數來設置,即 width: calc(100%/3 - 20px)。分成等寬的 3 列減掉左右兩遍的 margin 距離。

代碼實現:

<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
          display: flex;  
          flex-flow:column wrap;
          height: 100vh;
        }
        .item {
            margin: 10px;
            width: calc(100%/3 - 20px);
        }
        .item img{
            width: 100%;
            height:100%;
        }
    </style>
</head>
<body>
<div class="box">
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="show.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="cloth.jpg" alt="" />
    </div>
    <div class="item">
        <img  src="banner.jpg" alt="" />
    </div>
</div>
</body>

效果如下:
 

四、3種方式對比

如果只是簡單的頁面展示,可以使用 column 多欄布局和 flex 彈性布局。如果需要動態添加數據,或者動態設置列數,就需要使用到 JS + jQuery。

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

標簽:綏化 赤峰 盤錦 聊城 阿壩 金昌 萍鄉 中山

巨人網絡通訊聲明:本文標題《3種方式實現瀑布流布局小結》,本文關鍵詞  3種,方式,實現,瀑布,流,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《3種方式實現瀑布流布局小結》相關的同類信息!
  • 本頁收集關于3種方式實現瀑布流布局小結的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲精品国产一区二区三区四区在线| 成人免费精品视频| 亚洲成av人在线观看| 3atv一区二区三区| 丁香亚洲综合激情啪啪综合| 中文字幕色av一区二区三区| 国产欧美一区二区三区在线老狼| 在线观看日韩精品| 成人美女在线观看| 国内精品免费**视频| 日韩毛片精品高清免费| 日韩欧美高清dvd碟片| 色婷婷激情一区二区三区| 粉嫩高潮美女一区二区三区 | 亚洲成av人片在www色猫咪| 国产欧美精品国产国产专区| 中文字幕人成不卡一区| 国产精品久久夜| 国产精品女同一区二区三区| 久久久久久黄色| 精品国产乱码久久久久久免费 | 日韩欧美中文一区| 91免费观看国产| 99国产精品国产精品毛片| 成人黄色免费短视频| 一本大道久久a久久精二百| 成人av综合在线| 成人av先锋影音| 在线观看日韩一区| 91麻豆精品国产| 日韩一级片网址| 国产精品国产三级国产专播品爱网| 中文字幕精品一区二区三区精品| 一区二区三区在线免费观看| 国产精品一区二区在线播放| 日韩精品影音先锋| 日韩一区精品字幕| 欧美三区免费完整视频在线观看| 国产精品女人毛片| 91在线观看免费视频| 久久免费偷拍视频| 国产精品香蕉一区二区三区| 久久午夜免费电影| 国产在线视频不卡二| 久久婷婷国产综合国色天香| 韩国av一区二区三区| 久久久久国产成人精品亚洲午夜| 国产精品69毛片高清亚洲| 久久午夜色播影院免费高清| 国产精品一区二区三区网站| 久久精品人人爽人人爽| 成人黄色大片在线观看| 日韩毛片高清在线播放| 色一区在线观看| 亚洲福利一区二区| 26uuu欧美| 不卡av在线网| 日本不卡在线视频| 久久精品亚洲国产奇米99| 成人app在线| 免费看欧美女人艹b| 久久久精品免费免费| 成人的网站免费观看| 丝袜美腿高跟呻吟高潮一区| 国产亚洲一区二区在线观看| 99精品久久免费看蜜臀剧情介绍| 亚洲一区二区三区在线看| 久久精品夜色噜噜亚洲a∨| 91精品一区二区三区久久久久久| www.色综合.com| 另类欧美日韩国产在线| 午夜精品久久久久久久蜜桃app| 久久青草国产手机看片福利盒子| 欧美日韩在线播放一区| 99这里只有久久精品视频| 久久成人av少妇免费| 亚洲电影一级黄| 亚洲高清不卡在线| 亚洲精品国产视频| 国产精品久久三| 国产精品毛片a∨一区二区三区| 精品国产百合女同互慰| 日韩精品一区在线| 欧美一区二区三区在线观看| 在线观看av一区| 91精品在线一区二区| 欧美一区二区三区的| 欧美成人三级电影在线| 久久综合色8888| 免费观看成人鲁鲁鲁鲁鲁视频| 69精品人人人人| 欧美精品777| 日韩一级大片在线观看| 韩国女主播一区| 一区二区三区不卡视频| 91蝌蚪porny| 国产精品一区二区免费不卡| 国产精品久久久久7777按摩| 另类小说视频一区二区| 久久久99久久| 热久久一区二区| www.综合网.com| 久久精品一区二区三区不卡| 激情图片小说一区| 久久综合成人精品亚洲另类欧美| 精久久久久久久久久久| 日韩午夜激情av| 久久99国产精品麻豆| 91精品国产麻豆国产自产在线 | 精品美女被调教视频大全网站| 美女一区二区三区| 精品久久久久久久人人人人传媒| 日本成人中文字幕在线视频| 日韩一区二区三区在线视频| 免费成人在线视频观看| 日韩亚洲欧美中文三级| 麻豆精品在线视频| xnxx国产精品| 成人精品在线视频观看| 亚洲精品日日夜夜| 欧美性受xxxx黑人xyx性爽| 亚洲国产成人av网| 精品久久一区二区| 99精品国产视频| 亚洲精品久久7777| 日韩一级二级三级精品视频| 国产精品夜夜嗨| 亚洲精品综合在线| 欧美精品第一页| 国产精品一区二区91| 一区二区三区在线观看网站| 欧美一区二区三区四区久久| jizzjizzjizz欧美| 亚洲国产精品一区二区www| 日韩女优视频免费观看| 国产99久久久国产精品免费看| 一区2区3区在线看| 精品福利在线导航| 欧美在线free| 国产999精品久久久久久| 亚洲午夜电影在线| 国产日产亚洲精品系列| 欧美色区777第一页| 成人性生交大合| 九九国产精品视频| 亚洲狠狠爱一区二区三区| 日韩欧美激情一区| 欧美猛男男办公室激情| 成人av在线影院| 精品一区二区国语对白| 亚洲男人天堂av网| 久久久国产综合精品女国产盗摄| 欧美在线短视频| 99精品在线免费| 亚洲一区二区三区美女| 中文字幕av一区二区三区高| 日韩欧美亚洲另类制服综合在线| 91麻豆国产香蕉久久精品| 韩日精品视频一区| 视频一区二区三区中文字幕| 一区二区在线观看视频| 久久精品欧美日韩精品| 日韩三级高清在线| 欧美综合在线视频| 91女神在线视频| av成人免费在线| 精久久久久久久久久久| 欧美aⅴ一区二区三区视频| 亚洲成a人片在线不卡一二三区 | 日韩中文字幕不卡| 亚洲一区影音先锋| 亚洲人成在线观看一区二区| 国产午夜一区二区三区| 精品欧美一区二区久久| 欧美一级高清片在线观看| 91精品福利在线一区二区三区 | 亚洲国产成人av| 亚洲一区av在线| 洋洋成人永久网站入口| 中文字幕欧美日本乱码一线二线| 国产亚洲精久久久久久| 久久精品亚洲麻豆av一区二区| 久久久精品tv| 国产精品三级电影| 中文字幕在线不卡| 亚洲三级电影网站| 一区二区三区在线观看动漫| 亚洲综合视频在线观看| 亚洲va欧美va人人爽| 日韩黄色免费电影| 精品一区二区三区的国产在线播放| 精品一区二区日韩| 成人在线综合网| 一本久久综合亚洲鲁鲁五月天| 在线视频综合导航| 在线成人av影院| 久久久久高清精品| 1000精品久久久久久久久| 亚洲国产你懂的| 久久激情五月激情|