热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

thinkPHP实现瀑布流

很多人都想做瀑布流的效果,这里告诉大家官网使用的方法,首先要下载瀑布流的插件jquery.masonry.min.js地址:http://masonry.desandro.com/index.html里面包含的很多示例.

很多人都想做瀑布流的效果,这里告诉大家官网使用的方法,首先要下载瀑布流的插件jquery.masonry.min.js 地址:http://masonry.desandro.com/index.html里面包含的很多示例.

流程:

1,页面初始化时,调用插件进行一次排版;

2,当用户将滚动条拖到底部时,用ajax加载一次数据,并排版显示

3,重复2,直到无数据

Html代码:

  1. > 
  2. <html xmlns="http://www.w3.org/1999/xhtml"> 
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
  5. <title>Insert title heretitle> 
  6.  
  7. <style type="text/css"> 
  8. body {margin:40px auto; width:800px; font-size:12px; color:#666;} 
  9. .item{ 
  10. border: 1px solid #D4D4D4; 
  11. color: red; 
  12. margin: 0 10px 10px 0; 
  13. padding: 10px; 
  14. position: relative; 
  15. width: 200px; 
  16. .loading-wrap{ 
  17. bottom: 50px; 
  18. width: 100%; 
  19. height: 52px; 
  20. text-align: center; 
  21. display: none; 
  22. .loading { 
  23. padding: 10px 10px 10px 52px; 
  24. height: 32px; 
  25. line-height: 28px; 
  26. color: #FFF; 
  27. font-size: 20px; 
  28. border-radius: 5px; 
  29. background: 10px center rgba(0,0,0,.7); 
  30. .footer{ 
  31. border: 2px solid #D4D4D4; 
  32. style> 
  33.  
  34. head> 
  35. <body> 
  36.  
  37. <script type="text/Javascript" src="/test/public/Js/jquery-1.7.2.min.js">script> 
  38. <script type="text/Javascript" src="/test/public/Js/jquery.masonry.min.js">script> 
  39.  
  40.  
  41. <div id="container" class=" container"> 
  42.  
  43. <volist name="height" id="vo"> 
  44. <div class="item" style="height:{$vo}px;">瀑布流下来了div> 
  45. <input type="hidden" name="last_id" class="last_id" value="{$vo.id}"/> 
  46. volist> 
  47. div> 
  48.  
  49.  
  50. <div id="loading" class="loading-wrap"> 
  51. <span class="loading">加载中,请稍后...span> 
  52. div> 
  53.  
  54.  
  55. <div class="footer"><center>我是页脚center>div> 
  56.  
  57. <script type="text/Javascript"> 
  58. //用于转换unix时间戳 
  59. function unix_to_datetime(unix)  
  60. var now = new Date(parseInt(unix) * 1000); 
  61. return now.toLocaleString().replace(/年|月/g, "-").replace(/日/g, " "); 
  62. $(function(){ 
  63. //页面初始化时执行瀑布流 
  64. var $container = $(&#39;#container&#39;); 
  65. $container.masonry({ 
  66. itemSelector : &#39;.item&#39;, 
  67. isAnimated: true 
  68. }); 
  69. //用户拖动滚动条,达到底部时ajax加载一次数据 
  70. var loading = $("#loading").data("on", false);//通过给loading这个div增加属性on,来判断执行一次ajax请求 
  71. $(window).scroll(function(){ 
  72. if(loading.data("on")) return; 
  73. if($(document).scrollTop() > $(document).height()-$(window).height()-$(&#39;.footer&#39;).height()){//页面拖到底部了 
  74. //加载更多数据 
  75. loading.data("on", true).fadeIn(); //在这里将on设为true来阻止继续的ajax请求 
  76.  
  77. //获取最后一个id 
  78. var lastid = $(&#39;.last_id:last&#39;).val(); 
  79. $.get( 
  80. "getMore", //要跳转的页面 
  81. {lastid:lastid},//传值 
  82. function(data){ 
  83. //获取到了数据data,后面用JS将数据新增到页面上 
  84. var getdata = data.data; 
  85. var html = ""
  86. if($.isArray(getdata)){ 
  87. $.each(data.data,function(i,item) { 
  88. html += "<div class=\"item\" style=\"height:"+data[i]+"px;\">瀑布又流下来了div>"; 
  89. }); 
  90. var $newElems = $(html).css({ opacity: 0 }).appendTo($container); 
  91. $newElems.imagesLoaded(function(){ 
  92. $newElems.animate({ opacity: 1 }); 
  93. $container.masonry( &#39;appended&#39;, $newElems, true );  
  94. }); 
  95. //一次请求完成,将on设为false,可以进行下一次的请求 
  96. loading.data("on", false); 
  97. loading.fadeOut(); 
  98. }, 
  99. "json" 
  100. ); 
  101. }); 
  102. }); 
  103. script> 
  104. body> 
  105. html> 

Action代码

  1. //初始化的数据 
  2. public function lists(){  
  3. $data = D(&#39;Info&#39;)->order(&#39;id DESC&#39;)->limit(10)->select(); 
  4. $this->assign(&#39;data&#39;$data); 
  5. $this->display(); 
  6. //获取一次请求的数据 
  7. public function getMore(){  
  8. //获取最后一个id 
  9. if(!emptyempty($_GET[&#39;lastid&#39;]))$map[&#39;id&#39;] = array(&#39;lt&#39;$_GET[&#39;lastid&#39;]);  
  10. $data = D(&#39;Info&#39;)->where($map)->order(&#39;id DESC&#39;)->limit(10)->select(); 
  11. $this->ajaxReturn($data); 

注意:通过判断窗口是否滚动到页面底部来决定用ajax加载一次数据,如果不做处理,会一下子请求很多次,所以,要使用条件来限制.

我使用的是往一个元素上赋值 $("#loading").data("on", true);,在请求期间判断是true则不继续请求,然后在页面请求完成后再赋值为false.


推荐阅读
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 本文介绍了一段使用jQuery实现的用户注册页面表单验证代码,适用于前端开发人员学习和参考。该示例结合了HTML、CSS和JavaScript,确保用户输入的数据格式正确。 ... [详细]
  • 基于JQuery实现的评分插件
    本文介绍了一个使用JQuery创建的交互式评分控件。当用户将鼠标悬停在星星上时,左侧的星星会变为实心,右侧保持空心,并显示对应的评分等级;移开鼠标后,所有星星恢复为空心状态。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 本文详细介绍了如何使用 HTML 和 CSS 对文件上传按钮进行样式美化,使用户界面更加友好和美观。 ... [详细]
  • 当unique验证运到图片上传时
    2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
  • 理解文档对象模型(DOM)
    本文介绍了文档对象模型(DOM)的基本概念,包括其作为HTML文档的节点树结构,以及如何通过JavaScript操作DOM来实现网页的动态交互。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
author-avatar
mobiledu2502885807
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有