iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JS、flex 、column实现瀑布流布局的方式是怎样的
  • 452
分享到

JS、flex 、column实现瀑布流布局的方式是怎样的

2023-06-22 03:06:34 452人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关js、flex 、column实现瀑布流布局的方式是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、JS 实现瀑布流思路分析瀑布流布局的特点是等宽不等高。

这篇文章将为大家详细讲解有关js、flex 、column实现瀑布流布局的方式是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、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"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </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>

效果如下

JS、flex 、column实现瀑布流布局的方式是怎样的

二、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"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div></div></body>

效果如下:

JS、flex 、column实现瀑布流布局的方式是怎样的

三、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"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="show.jpg"  />    </div>    <div class="item">        <img  src="cloth.jpg"  />    </div>    <div class="item">        <img  src="banner.jpg"  />    </div></div></body>

效果如下:

JS、flex 、column实现瀑布流布局的方式是怎样的

四、3种方式对比

如果只是简单的页面展示,可以使用 column 多栏布局和 flex 弹性布局。如果需要动态添加数据,或者动态设置列数,就需要使用到 JS + jQuery。

关于JS、flex 、column实现瀑布流布局的方式是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: JS、flex 、column实现瀑布流布局的方式是怎样的

本文链接: https://www.lsjlt.com/news/302213.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JS、flex 、column实现瀑布流布局的方式是怎样的
    这篇文章将为大家详细讲解有关JS、flex 、column实现瀑布流布局的方式是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、JS 实现瀑布流思路分析瀑布流布局的特点是等宽不等高。...
    99+
    2023-06-22
  • 实现瀑布流布局的三种方式
    前言 今天逛闲鱼的时候观察到每一行的高度不是相同的,经了解才知道原来这是一种瀑布流布局,感觉挺有意思,于是决定研究一下,在网上也找了一些方案,实现瀑布流大概有3种方式。 一、JS 实...
    99+
    2024-04-02
  • 原生js怎么实现瀑布流布局
    这篇文章主要介绍原生js怎么实现瀑布流布局,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!用js实现瀑布流布局以及通过模拟的数据加载图片,已标记注释效果如图:<!DOCTYPE&...
    99+
    2024-04-02
  • 如何用js实现瀑布流布局
    这篇“如何用js实现瀑布流布局”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何用js实现瀑布流布局”文章吧。一、前端代码编...
    99+
    2023-07-05
  • 如何使用Css Flex 弹性布局实现瀑布流布局
    随着网页设计的不断发展,瀑布流布局成为了一种非常流行的页面布局方式。与传统的网格布局不同,瀑布流布局能够自适应屏幕大小,并且呈现出独特的流动感。在本文中,我们将介绍如何使用CSS Flex 弹性布局来实现瀑布流布局,并提供具体的代码示例。C...
    99+
    2023-10-21
    瀑布流布局 弹性布局 CSS flex
  • 怎么用JS实现网页瀑布流布局
    这篇文章主要介绍怎么用JS实现网页瀑布流布局,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JS是什么JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分...
    99+
    2023-06-14
  • 怎么实现瀑布流布局
    本篇文章给大家分享的是有关怎么实现瀑布流布局,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、JS 实现瀑布流思路分析瀑布流布局的特点是等宽不等高。为了让最后一行的差距最小,从...
    99+
    2023-06-09
  • js实现瀑布流布局(无限加载)
    本文实例为大家分享了js实现瀑布流布局的具体代码,供大家参考,具体内容如下 1.实现瀑布流布局思路 准备好数据之后 . 绑定滚动事件 . 判断页面是否到底(滚动的距离+可是区域的高度...
    99+
    2024-04-02
  • js实现瀑布流的方式有哪些
    使用原生JavaScript实现:通过计算每一列的高度,将新的元素添加到高度最小的列中,从而实现瀑布流布局。 使用jQuer...
    99+
    2024-03-08
    JS
  • 如何用JS实现网页瀑布流布局
    目录前言: 什么是瀑布流布局: 如何实现: 1. 获取图片2. 设置图片宽带3. 计算浏览器页面一行最多能存放图片的数量4. 比较图片高度 5. 得到上一行中最小高度图片的位置6. ...
    99+
    2024-04-02
  • CSS布局教程:实现瀑布流式卡片布局的最佳方法
    引言:在现代网页设计中,瀑布流式卡片布局是非常流行的一种布局方式。它能够有效地展示大量的内容,并且在不同的屏幕尺寸下都能够自适应,给用户带来良好的浏览体验。本文将介绍实现瀑布流式卡片布局的最佳方法,并提供具体的代码示例。一、实现瀑布流式布局...
    99+
    2023-10-21
    CSS 瀑布流 布局
  • uniapp瀑布流布局怎么实现
    要实现uniapp中的瀑布流布局,可以使用uniapp提供的mescroll组件,通过配置该组件实现瀑布流效果。以下是实现瀑布流布局...
    99+
    2024-03-08
    uniapp
  • 怎么在css3中利用column实现卡片瀑布流布局
    这篇文章将为大家详细讲解有关怎么在css3中利用column实现卡片瀑布流布局,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。相关属性column-count:想实现的列数,我这里只需要2列c...
    99+
    2023-06-08
  • CSS布局教程:实现瀑布流布局的最佳方法
    瀑布流布局(Waterfall Layout)是一种常见的网页布局方式,它可以使不同大小的元素以多列的形式依次排列,给人一种瀑布水流般的感觉。这种布局常用于照片墙、产品展示等需要展示多个项目的网页。本文将介绍如何使用CSS实现瀑布流布局,并...
    99+
    2023-10-21
    瀑布流布局 最佳方法 CSS布局
  • 手把手教你用js实现瀑布流布局
    它可以有效的降低页面的复杂度,节省很多的空间;并且,瀑布流的参差不齐的排列方式,可以通过界面展示给用户多条数据,并且让用户可以有向下浏览的冲动,提供了很好的用户体验!例如淘宝的页面就采用了这种布局方式,给大家看看淘宝的瀑布流布局的效果图(手...
    99+
    2023-05-14
    JavaScript
  • 如何使用JS或CSS实现瀑布流布局
    本篇内容主要讲解“如何使用JS或CSS实现瀑布流布局”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用JS或CSS实现瀑布流布局”吧!本着实用精神,我们今天...
    99+
    2024-04-02
  • vue+uniapp瀑布流布局怎么实现
    这篇“vue+uniapp瀑布流布局怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue+uniapp瀑布流布局怎么...
    99+
    2023-07-05
  • JavaScript实现瀑布流布局的代码分享
    目录前言如何实现html部分css部分js部分瀑布流布局的优点前言 不知道大家在线上购物的时候有没有发现到,自己逛起来根本就停不下来,越往下翻越是觉得就会出现需要的东西。这就是很多电...
    99+
    2023-05-15
    JavaScript实现瀑布流布局 JavaScript瀑布流布局 JavaScript瀑布流
  • CSS属性实现瀑布流布局的技巧
    CSS属性实现瀑布流布局的技巧,需要具体代码示例瀑布流布局是一种常见的网页布局方式,特点是将网页内容像瀑布一样从上到下依次排列,且每个内容块的宽度固定,高度可以不同。这种布局方式可以使网页显示更加美观,给用户带来良好的视觉体验。在CSS中,...
    99+
    2023-11-18
    瀑布流布局 技巧 CSS属性
  • 小程序中怎么实现瀑布流布局
    这篇文章将为大家详细讲解有关小程序中怎么实现瀑布流布局,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。widthFix:宽度不变,高度自动变化,保持原图宽高比不变。配合column-count...
    99+
    2023-06-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作