瀑布流的小例子和ThinkPHP相结合

瀑布流的插件jquery.masonry.min.js 地址:http://masonry.desandro.com/index.html里面有很 多,但是都是英文的,因为项目需要,就自己写了一个简单的例子

其实瀑布流就是用了固定的宽度或者高度产生一堆不规则的div来展现出来的。

流程是

1:初始化页面的时候加载一次数据

2.当页面到底部的时候再次加载数据

3,重 复以上操作直到没有数据

<!DOCTYPE HTML>
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Insert title here</title>
 <!--样式-->
 <style type="text/css">
body {margin:40px auto; width:800px; font-size:12px; color:#666;}
 .item{
    border: 1px solid #D4D4D4;
    color: red;
    margin: 0 10px 10px 0;
    padding: 10px;
    position: relative;
    width: 200px;
 }
 .loading-wrap{
    bottom: 50px;
    width: 100%;
    height: 52px;
    text-align: center;
    display: none;
 }
 .loading {
    padding: 10px 10px 10px 52px;
    height: 32px;
    line-height: 28px;
    color: #FFF;
    font-size: 20px;
    border-radius: 5px;
    background: 10px center rgba(0,0,0,.7);
 }
 .footer{
    border: 2px solid #D4D4D4;
 }
 </style>
 <!--样式-->
 </head>
 <body>
 <!--引入所需要的jquery和插件-->
 <script type="text/javascript" src="/test/public/Js/jquery-

1.7.2.min.js"></script>
 <script type="text/javascript" 

src="/test/public/Js/jquery.masonry.min.js"></script>
 <!--引入所需要的jquery和插件-->
 <!--瀑布流-->
 <div id="container" class=" container">
 <!--这里通过设置每个div不同的高度,来凸显布局的效果-->
 <volist name="height" id="vo">
    <div class="item" style="height:{$vo}px;">瀑布流下来了</div>
 </volist>
 </div>
 <!--瀑布流-->
 <!--加载中-->
 <div id="loading" class="loading-wrap">
    <span class="loading">加载中,请稍后...</span>
 </div>
 <!--加载中-->
 <!--尾部-->
 <div class="footer"><center>我是页脚</center></div>
 <!--尾部-->
 <script type="text/javascript">
$(function(){
    //页面初始化时执行瀑布流
    var $container = $('#container');
     $container.masonry({
        itemSelector : '.item',
        isAnimated: true
     });
     //用户拖动滚动条,达到底部时ajax加载一次数据
    var loading = $("#loading").data("on", false);//通过给loading这个div增加属性on,来判断执行一次ajax请求
    $(window).scroll(function(){
        if(loading.data("on")) return;
        if($(document).scrollTop() > $(document).height()-$(window).height()-$('.footer').height()){//页面拖到底部了
            //加载更多数据
            loading.data("on", true).fadeIn();         //在这里将on设为true来阻止继续的ajax请求
            $.get(
                "getMore",
                function(data){
                   //获取到了数据data,后面用JS将数据新增到页面上
                    var html = "";
                    if($.isArray(data)){
                        for(i in data){
                            html += "<div class=\"item\" style=\"height:"+data[i]+"px;\">瀑布又流下来了</div>";
                        }
                        var $newElems = $(html).css({ opacity: 0 }).appendTo($container);
                        $newElems.imagesLoaded(function(){
                            $newElems.animate({ opacity: 1 });
                            $container.masonry( 'appended', $newElems, true );
                              });
                      //一次请求完成,将on设为false,可以进行下一次的请求
                        loading.data("on", false);
                    }
                    loading.fadeOut();
                },
                "json"
            );
        }
    });
 });
 </script>
 </body>
 </html>

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据
, 页面
, masonry
, 瀑布流
, container
, data
, px
, loading
, 使用jquery masonry
, ios瀑布流的实现
, ajax瀑布流
, js瀑布流加载图片
, jquery瀑布流插件
瀑布流插件
thinkphp瀑布流、理论与实践相结合例子、thinkphp增删改查例子、thinkphp cli模式例子、thinkphp 例子,以便于您获取更多的相关知识。

时间: 2024-10-03 14:40:09

瀑布流的小例子和ThinkPHP相结合的相关文章

PHP+Jquery与ajax相结合实现下拉淡出瀑布流效果【无需插件】_php实例

导读: 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早采用此布局的网站是Pinterest,逐渐在国内流行开来.国内大多数清新站基本为这类风格,像花瓣网.蘑菇街.美丽说等. 不废话,直接上代码,整段代码分为前后两段代码,具体代码如下所示. 前台: <?php <br>$category=$this->getMyVal('category',$_GET);<br>

说说瀑布流式网站里那些可人的小细节

瀑布流式布局,想必设计师们已不再陌生,随着pinterest自2011年开始走红,瀑布流式的布局被越来越多的网站所使用.花瓣网.堆糖网.布兜.发现啦,美丽说,蘑菇街,人人逛街,凡客达人等,复制Pinterest的网站在中国蜂拥而现,粗略估计已有几十家之多. 为什么选择瀑布流? 既然pinterest式蜂拥而现,我们先从体验角度看,瀑布流布局为什么好? 笔者浅见.随着读图时代快餐式消费的来临,瀑布流对于图片的展现,是高效而具有吸引力的,用户一眼扫过的快速阅读模式可以在短时间内获得更多的信息量,而瀑

thinkPHP实现瀑布流的方法_php实例

本文实例讲述了thinkPHP实现瀑布流的方法.分享给大家供大家参考.具体分析如下: 很多人都想做瀑布流的效果,这里告诉大家官网使用的方法,首先要下载瀑布流的插件jquery.masonry.min.js 地址:http://masonry.desandro.com/index.html里面包含的很多示例. 流程: 1. 页面初始化时,调用插件进行一次排版: 2. 当用户将滚动条拖到底部时,用ajax加载一次数据,并排版显示 3. 重复2,直到无数据 Html代码: 复制代码 代码如下: <!D

读图年代:微博进行瀑布流的交互方式

"读图年代"将新浪微博与类似 Pinterest 瀑布流的交互方式相结合,让用户感觉到了不一样的阅读体验. 极客公园曾经探讨过Pinterest模式的流行是否意味着读图时代已经来到我们的面前,无可否认,读图已经成为一个热门话题,各种应用也是层出不穷.今天介绍的"读图年代"将类似 Pinterest 化的瀑布流阅读方式引进到新浪微博之中,使得用户可以轻松阅读微博海量信息,同时将各类信息集合并分类以方便用户浏览,以节省搜索的时间成本. "读图年代"的

Android App中实现相册瀑布流展示的实例分享_Android

传统界面的布局方式总是行列分明.坐落有序的,这种布局已是司空见惯,在不知不觉中大家都已经对它产生了审美疲劳.这个时候瀑布流布局的出现,就给人带来了耳目一新的感觉,这种布局虽然看上去貌似毫无规律,但是却有一种说不上来的美感,以至于涌现出了大批的网站和应用纷纷使用这种新颖的布局来设计界面. 记得我在之前已经写过一篇关于如何在Android上实现照片墙功能的文章了,但那个时候是使用的GridView来进行布局的,这种布局方式只适用于"墙"上的每张图片大小都相同的情况,如果图片的大小参差不齐,

jQuery向下滚动即时加载内容实现的瀑布流效果_php实例

下拉滚动条或鼠标滚轮滚动到页面底部时, 动态即时加载新内容. 后台用 json 传输数据, 示例程序中只写了示例数组.数据也只设置了两个属性, 需根据实际应用改写. 页面用了 ul li 做为容器, 每个 li 表示一列 <ul id="stage"> <li></li> <li></li> <li></li> PHP和Jquery和ajax实现下拉淡出瀑布流效果(无需插件) <li><

Android瀑布流照片墙实现 体验不规则排列的美感_Android

传统界面的布局方式总是行列分明.坐落有序的,这种布局已是司空见惯,在不知不觉中大家都已经对它产生了审美疲劳.这个时候瀑布流布局的出现,就给人带来了耳目一新的感觉,这种布局虽然看上去貌似毫无规律,但是却有一种说不上来的美感,以至于涌现出了大批的网站和应用纷纷使用这种新颖的布局来设计界面. 记得我在之前已经写过一篇关于如何在Android上实现照片墙功能的文章了,但那个时候是使用的GridView来进行布局的,这种布局方式只适用于"墙"上的每张图片大小都相同的情况,如果图片的大小参差不齐,

Android App中实现相册瀑布流展示的实例分享

传统界面的布局方式总是行列分明.坐落有序的,这种布局已是司空见惯,在不知不觉中大家都已经对它产生了审美疲劳.这个时候瀑布流布局的出现,就给人带来了耳目一新的感觉,这种布局虽然看上去貌似毫无规律,但是却有一种说不上来的美感,以至于涌现出了大批的网站和应用纷纷使用这种新颖的布局来设计界面. 记得我在之前已经写过一篇关于如何在Android上实现照片墙功能的文章了,但那个时候是使用的GridView来进行布局的,这种布局方式只适用于"墙"上的每张图片大小都相同的情况,如果图片的大小参差不齐,

瀑布流的布局方式:360图片搜索美女图片瀑布流布局分析

文章简介:瀑布流的布局方式展现的内容通常是扁平化.琐碎的东西.首先吸引人的应该是图片,并且图片是那种参差不齐的,如果瀑布流中文字过多,会给人很杂乱的感觉,所以瀑布流更适合单纯的图片浏览. 瀑布流的布局方式展现的内容通常是扁平化.琐碎的东西.首先吸引人的应该是图片,并且图片是那种参差不齐的,如果瀑布流中文字过多,会给人很杂乱的感觉,所以瀑布流更适合单纯的图片浏览. 前不久公司上线的项目–360图片搜索的美女秀场频道,就用到了瀑布流的布局方式,这种纯粹的看美女图片的页面用瀑布流还是挺合适的. 以前并