首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

jquery图片列表瀑布流布局代码

基础概念

瀑布流布局(Masonry Layout)是一种流行的网页布局方式,它将元素以多列的形式排列,每列的高度根据元素的高度动态调整,使得布局看起来像瀑布一样错落有致。这种布局方式特别适合图片展示,因为它能够充分利用屏幕空间,使图片展示更加美观。

相关优势

  1. 视觉效果好:瀑布流布局能够使页面看起来更加美观,提升用户体验。
  2. 空间利用率高:通过动态调整列的高度,能够充分利用屏幕空间,减少空白区域。
  3. 响应式设计:瀑布流布局可以很容易地适应不同的屏幕尺寸,实现响应式设计。

类型

瀑布流布局主要分为两种类型:

  1. 固定列宽:每列的宽度固定,高度根据内容动态调整。
  2. 固定行高:每行的高度固定,宽度根据内容动态调整。

应用场景

瀑布流布局常用于图片展示网站、商品展示网站、博客文章列表等场景。

示例代码

以下是一个使用 jQuery 实现的图片列表瀑布流布局的示例代码:

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>jQuery 瀑布流布局</title>
    <style>
        .container {
            position: relative;
            width: 100%;
        }
        .item {
            position: absolute;
            width: 200px;
            margin: 5px;
            background-color: #fff;
            box-shadow: 0 2px 5px rgba(0,0,0,0.3);
        }
        .item img {
            width: 100%;
            height: auto;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="item"><img src="image1.jpg" alt="Image 1"></div>
        <div class="item"><img src="image2.jpg" alt="Image 2"></div>
        <div class="item"><img src="image3.jpg" alt="Image 3"></div>
        <!-- 添加更多图片项 -->
    </div>

    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
    <script>
        $(document).ready(function() {
            function layoutItems() {
                var container = $('.container');
                var itemWidth = 200 + 10; // 每个 item 的宽度加上 margin
                var columns = Math.floor(container.width() / itemWidth);
                var columnHeights = new Array(columns).fill(0);

                $('.item').each(function() {
                    var minHeightIndex = columnHeights.indexOf(Math.min(...columnHeights));
                    $(this).css({
                        left: minHeightIndex * itemWidth,
                        top: columnHeights[minHeightIndex]
                    });
                    columnHeights[minHeightIndex] += $(this).outerHeight() + 10;
                });

                container.height(Math.max(...columnHeights));
            }

            layoutItems();
            $(window).resize(layoutItems);
        });
    </script>
</body>
</html>

解决常见问题

  1. 图片加载延迟:如果图片加载较慢,可能会导致布局错乱。可以使用图片预加载技术来解决这个问题。
  2. 窗口大小变化:当窗口大小变化时,布局需要重新计算。可以通过监听窗口的 resize 事件来实现。
代码语言:txt
复制
$(window).resize(layoutItems);
  1. 动态添加元素:如果需要在页面加载后动态添加新的图片项,需要在添加元素后重新调用布局函数。
代码语言:txt
复制
function addItem(src) {
    var newItem = $('<div class="item"><img src="' + src + '" alt="New Image"></div>');
    $('.container').append(newItem);
    layoutItems();
}

通过以上方法,可以实现一个简单且高效的 jQuery 图片列表瀑布流布局。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 浅析瀑布流布局及其原理视频_jquery瀑布流布局

    一、什么是瀑布流 很多时候我们会看到一些Vlog网站或者展示图片的网站,它们的图片明明每一张的高度大小都不同,但是却能自动地适应,排成一行一行地展示,并且下拉到底的时候,加载的图片也会自动适应,这就是瀑布流...二、实现原理 要做到每一张图片都根据上面的高度自动适应排列,那么我们就不能单纯地靠html+css布局了,需要用到js来帮助计算位置(其实用CSS3也能布局)。那么计算什么呢?...三、事先准备 建议事前在网上随便下载15张以上的图片,不用理会长宽问题,这些都是可以用css设置的; 准备好jQuery 然后按照以下布局去把HTML结构和CSS样式写好: 瀑布流的核心 实现瀑布流的核心其实就两个: 找出图片高度最小的那一列,再那一列插入,然后继续找下一个高度最小的,一直循环直到插满图片为止; 计算出每一列距离浏览器整体的距离,也就是position里的...当你知道某一列的left的时候,相当于就知道了在它下面插入图片时,图片如何定位到这一列了,只要图片的left值和列是一样的,那么图片自然就插入到列里面了 实现代码如下: var data=[ {"src

    1.4K20

    JS实现瀑布流页面布局

    个人对瀑布流布局理解: 每列的宽度相等而高度不等,且第二行的第一个容器需要放在第一行高度最小的容器下面,依次类推放置。...附上代码: 代码仅实现了瀑布流的布局方式和 resize 监听,如果大家有需要,可以自己拓展下:实现监听滚动事件,页面滚动加载图片的功能。 代码中写了详细注释,可以直接使用。 瀑布流布局...(pageWidth / (itemWidth + gap)); // 瀑布流实现原则: // 所有图片元素绝对定位,从第二行开始,依次从第一行图片元素高度最小的下方填充...,这里注意,不是从左至右填充,即优先填补空位,填补一个后,再填补下一个较大的空位 // 定义第一行图片的所有高度的数组,之后每张图片下方填充图片后,会更新数组对应位置下的最小高度

    2.8K40

    iOS 瀑布流之栅格布局

    :1)、纵长方形(1:2),动态的根据服务器下发模块样式绘制布局,可以横向滑动,限定为两行的高度。...答案当然是用UICollectionView了,然后自定义流水布局UICollectionViewLayout,主要代码如下:计算记录每一个cell对应的布局属性。...这个样式的栅格布局我已封装集成在WSLWaterFlowLayout 中,详情可以前往下载。...CGRectMake(x, y, w, h); } 后台下发字段格式示意图 功能描述:WSLWaterFlowLayout 是在继承于UICollectionViewLayout的基础上封装的带头脚视图的瀑布流控件...目前支持竖向瀑布流(item等宽不等高、支持头脚视图)、水平瀑布流(item等高不等宽 不支持头脚视图)、竖向瀑布流( item等高不等宽、支持头脚视图)、栅格布局瀑布流 4种样式的瀑布流布局。

    1.8K10

    图片瀑布流,so easy!

    什么是图片瀑布流 用一张花瓣网页的图片布局可以很清楚看出图片瀑布流的样子: ?...简单来说,就是有很多图片平铺在页面上,每张图片的宽度相同,但是高度不同,这样错落有致的排列出 n 列的样子很像瀑布,于是就有了瀑布流图片一说。...实现原理 1、第一种方式 第一种方式前提是:图片的宽度固定,但是列可变(根据屏幕大小) 通过上面的介绍,我们知道要实现瀑布流的前提是宽度一致(假如为100px),高度可以不相同。...实现代码 下面是未处理的原始代码,图片之间间隔很多空白,影响美观。 图片,将图片放入容器高度最小的容器中即可。 这里我们使用js来添加图片,而不是事先写好在html中了。 实现代码 <!

    1.6K10

    多栏布局与JS实现瀑布流

    css3属性之多栏布局与JS实现瀑布流    背景:之前打算自己总结一下flex布局的知识点,发现自己无从下手,原因在何处:我反思了一下,其实原因很简单,使用的次数少,更多的时间使用了百分比,浮动和定位解决...column-width宽度时,同时设置盒子的width,否则宽度默认为100%,每栏宽度按栏数平均分;盒子每栏宽度必须大于等于column-width设定的值,否则就会减少栏数来增加每栏宽度 css3多列和JS实现瀑布流... 给自己安利一波吧,看到网上很多瀑布流的效果,哇,简直棒极了有没有;于是我迫不及待的打开V**,打开了pinterest的官网。...自己也梳理梳理逻辑:代码之前,一定要先搞清逻辑,再动手写代码> 我们都不陌生瀑布流是同宽的,但是高度不一,js主要的工作就是根据高度来进行布局, 1)当一行排满后,准备排第二行的时候,...梳理完逻辑,让我们动手写代码吧: html比较简单,这里图片我用了placehold的图片占位符,如果你没有很好的素材,这也许是个不错的选择 <div class="main

    3K90

    干货 | 如何实现jQuery响应式瀑布流 ?

    开门见山,本文介绍响应式的瀑布流的实现方法。 最终效果图如下,改变浏览器大小效果更棒哦~ ?...以下我们将每个瀑布流盒子简称为box 使用数组记录每个box宽和高 ---- 设置不同屏幕宽度下每一行box的数量 使用$(window).width()获取屏幕宽度 根据不同屏幕宽度设置每一行box的数量...absolute";this.width = width;this.height = height;this.top = top;this.left = left;} 创建数组记录元素宽高 这里简述一下瀑布流原理...图片加载过程可能影响对box高度判断 可通过img.load来确保图片加载完成或者失败之后才进行计算 代码优化&封装 尽情发挥你的创造力吧 结束语 ---- 这个效果是我从别人的博客看到的,然后自己用...jQuery实现,这也不失为创造的乐趣呢。

    1.8K20

    Swift 自定义布局实现瀑布流视图

    ,瀑布流视图的惊艳之处就在于它的每个 Cell 的尺寸都是不一致的,那如何生成动态高度的 Cell 呢!...了解完需要实现的函数后,接下来就开始计算瀑布流视图的布局属性了,在这里我先讲一下我实现的大概思路吧!...由于我们瀑布流视图的每个 Cell 的高度是动态的,为了实现这个需求,我们可以声明一个 protocol 并提供一个返回动态高度的方法,来为每个 Cell 提供动态的高度,代码如下: protocol...,然后并把相交的属性返回 好了,到这里关于瀑布流视图的布局就讲完了,附上 WaterFallFlowLayout 的全部代码,供大家参考: import UIKit protocol WaterFallLayoutDelegate...Xcode 工程中编译并运行,你就会看到 Cell 根据照片的高度正确放置并设置了大小: 好了, 利用 UICollectionView 控件与自定义布局实现瀑布流的内容到此就结束了,最后附上项目的源码地址

    2.6K30
    领券