3种方法完成瀑布流合理布局小结

日期:2021-02-22 类型:科技新闻 

关键词:在线网页制作,建网页,个人简介网页制作,简单网页,建立网页

序言

今日逛闲鱼的情况下观查到每行的高宽比并不是同样的,经掌握才了解原先这是1种瀑布流合理布局,觉得挺成心思,因而决策科学研究1下,在网络上也找了1些计划方案,完成瀑布流大约有3种方法。

1、JS 完成瀑布流

思路剖析

  • 瀑布流合理布局的特性是等宽不等高。
  • 以便让最终1行的差别最少,从第2行刚开始,必须将照片放在第1行最矮的照片下面,以此类推。
  • 父元素设定为相对性精准定位,照片所属元素设定为肯定精准定位。随后根据设定 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⑻;
        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 第1行按顺序合理布局
                $(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 设定下1行的第1个盒子部位
                // 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>

实际效果以下
 

2、column 多行合理布局完成瀑布流

思路剖析:

column 完成瀑布流关键依靠两个特性。
1个是 column-count 特性,是分成是多少列。
1个是 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>

实际效果以下:
 

3、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>

实际效果以下:
 

4、3种方法比照

假如只是简易的网页页面展现,可使用 column 多栏合理布局和 flex 延展性合理布局。假如必须动态性加上数据信息,或动态性设定列数,就必须应用到 JS + jQuery。

以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。