本文实例为大家分享了JQuery实现简单瀑布流布局的具体代码,供大家参考,具体内容如下

分享一个基于JQuery实现的瀑布流布局,效果如下: 

实现代码如下,欢迎大家复制粘贴。

<!DOCTYPE html>
<html>
 
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>基于JQuery实现的瀑布流布局案例</title>
    <style type="text/css">
        * {
            padding: 0;
            margin: 0;
        }
 
        #main {
            position: relative;
        }
 
        .pin {
            padding: 15px 0 0 15px;
            float: left;
        }
 
        .box {
            padding: 10px;
            border: 1px solid #ccc;
            box-shadow: 0 0 6px #ccc;
            border-radius: 5px;
        }
 
        .box img {
            width: 162px;
            height: auto;
        }
    </style>
</head>
 
<body>
    <div id="main">
        <div class="pin">
            <div class="box">
                <img src="./images/1.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/2.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/3.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/4.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/5.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/6.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/7.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/8.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/9.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/10.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/11.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/12.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/13.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/14.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/15.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/16.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/17.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/18.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/19.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/20.jpg" />
            </div>
        </div>
        <div class="pin">
            <div class="box">
                <img src="./images/21.jpg" />
            </div>
        </div>
    </div>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js" />
    </script>
    <script>
        $(window).on("load", function () {
            //调用瀑布流函数
            waterfall('main', 'pin');
            //模拟json数据
            var dataInt = { 'data': [{ 'src': '1.jpg' }, { 'src': '2.jpg' }, { 'src': '3.jpg' }, { 'src': '4.jpg' }] };
            //滚动加载
            window.onscroll = function () {
                //判断是否具备加载剩余图片
                if (checkscrollside()) {
 
                    //遍历模拟的json数据中dataInt.data值,得出下标和值
                    $.each(dataInt.data, function (index, value) {
 
                        //创建div添加class为pin,添加到ID为main的div中
                        var $oPin = $('<div>').addClass('pin').appendTo($("#main"));
 
                        //创建div添加class为box,添加到class为pin的div中
                        var $oBox = $('<div>').addClass('box').appendTo($oPin);
 
                        //创建图片添加src属性添加到class为box的div中
                        $('<img>').attr('src', './images/'   $(value).attr('src')).appendTo($oBox);
                    });
 
                    //调用瀑布流功能函数,让加载的图片按规则排列
                    waterfall();
                };
            }
        });
 
        //瀑布流功能函数
        function waterfall(parent, pin) {
 
            //获取所有图片容器(含内边距)
            var $aPin = $("#main>div");
 
            //获取其中一列的宽度 (outerWidth()可以获取padding值,width()无法获取)
            var iPinW = $aPin.eq(0).width();
 
            //通过整个窗口的宽度除以单列的宽度得出多少列,并向下取整
            var num = Math.floor($(window).width() / iPinW);
 
            //设置图片容器的宽度,并居中显示
            $("#main").css({
                'width:': iPinW * num,
                'margin': '0 auto'
            });
 
            //存储每一行当中列的高度
            var pinHArr = [];
 
            //遍历所有的图片容器,得出下标和值
            $aPin.each(function (index, value) {
 
                //将当前图片的高度存在pinH中
                var pinH = $aPin.eq(index).height();
 
                //如果图片容器的下标小于当前的列数,即只有一行
                if (index < num) {
 
                    //将第一行每一张图片的高度存在数组中
                    pinHArr[index] = pinH;
 
                } else {
 
                    //通过Math.min.apply求出数组pinHArr(第一行)中高度的最小值 
                    var minH = Math.min.apply(null, pinHArr);
 
                    //通过inArray(判断的值,所在数组)得出高度最小那张图片的下标
                    var minHIndex = $.inArray(minH, pinHArr);
 
                    //设置剩余图片的样式,value为Dom对象,要将其转换为JQuery对象
                    $(value).css({
                        //绝对定位
                        'position': 'absolute',
                        //top值 
                        'top': minH   15,
                        //left值为第一行中高度最小图片的left值
                        'left': $aPin.eq(minHIndex).position().left
                    });
                    //设置每一行中高度最小那一列的高度等于该列剩余图片高度的累加
                    pinHArr[minHIndex]  = $aPin.eq(index).height()   15;
                }
            });
        }
 
        //封装函数,检验是否需要加载图片
        function checkscrollside() {
 
            //获取所有图片容器(含内边距)
            var $aPin = $("#main>div");
 
            //将最后一张图片的top值加上该图片自身高度的一半存为变量lastPinH中
            //注意last()获得的是一个数组,通过get(0)获得第一个
            var lastPinH = $aPin.last().get(0).offsetTop   Math.floor($aPin.last().height() / 2);
 
            //获取页面滚动的距离
            var scrollTop = $(window).scrollTop();
 
            //获取屏幕高度
            var documentH = $(document).height();
 
            //当lastPinH小于页面滚动距离与屏幕高度之和时,返回true,具备加载条件,否则返回false,不具备
            return (lastPinH < scrollTop   documentH) ? true : false;
        }
 
    </script>
</body>
 
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

JQuery实现简单瀑布流布局的更多相关文章

  1. HTML5 canvas 瀑布流文字效果的示例代码

    这篇文章主要介绍了HTML5 canvas 瀑布流文字效果的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. 小程序瀑布流解决左右两边高度差距过大的问题

    这篇文章主要介绍了小程序瀑布流解决左右两边高度差距过大的问题的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  4. 3种方式实现瀑布流布局小结

    这篇文章主要介绍了3种方式实现瀑布流布局小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. 在IOS9中的Cordova应用程序使用JQuery / Javascript的window.history问题

    在两个测试用例中唯一改变的是Cordova.js.解决方法我看到这是几个星期前,但我会发布这个,以防其他人遇到它.听起来它可能与iOS9中的哈希更改生成的导航事件有关.如果是这样,可以将其添加到index.html以禁用哈希侦听:

  6. iOS 5上的jQuery事件

    解决方法在Apple开发论坛上由一个人回答:我需要在将元素添加到DOM之后才绑定(),如下所示:

  7. Swift:用UICollectionView整一个瀑布流

    除了以上说到的内容之外,collectionview还有一个专门处理布局的UICollectionViewLayout。苹果给了一个基础的布局UICollectionViewFlowLayout,可以实现一个基本的流式布局。直接干掉,拖一个UICollectionViewController进去并设置为默认的Controller。之后在interfacebuilder中把collectionview的类设置为HomeCollectionViewController。接下来再次回到collectionvie

  8. Swift UITableView瀑布流/NSURLConnection异步网络请求

    去年写过一个OC版本的瀑布流Demo《UITableView实现的瀑布流效果》。接触Swift一段时间了,今天就是用Swift再写了一个瀑布流的Demo。原理是一样的这里不再赘述。在写这个Demo的过程中是用到了NSURLConnection的异步网络请求和GCD做了一个图片的异步加载,没有做图片的缓存,所以是用起来有些卡。cell是带左滑删除视图的,删除功能是没有实现的。O(∩_∩)O哈哈~

  9. android – Phonegap本地构建 – jquery ajax错误:readystate 0 responsetext status 0 statustext error

    解决方法您是否在索引文件中包含了内容安全元标记?

  10. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部