<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>定宽Jquery+AJAX+JSON瀑布流布局(每行代码都有详细注释)</title>
<style type="text/css">
body, ul, li, h3 { margin: 0; padding: 0; list-style: none; font: bold 12px "微软雅黑"; }
/*瀑布流布局样式*/
#lxf-box { position: relative; width: 1000px; margin:0 auto;}
#lxf-box li { background: #fff; border: solid 1px #ccc; text-align: center; padding: 10px; float: left;}
h3 { padding-top: 8px; }
img { width: 200px; height: auto; display: block; border: 0 }
/*css3动画 注由于是css3制作的所以兼容性不保证 要想兼容性好 请自己做成gif动画加载图*/
/*li { -webkit-transition: all .7s ease-out .1s; -moz-transition: all .7s ease-out; -o-transition: all .7s ease-out .1s; transition: all .7s ease-out .1s }*/
#loading { display:none; line-height: 30px; background: #000; color:#fff; text-align: center; height: 30px; width: 100%; position:fixed; bottom:0; opacity:0.8;}
</style>
<script src="http://www.iiwnet.com/templets/niu/js/jquery.min.js" type="text/javascript"></script>
</head>
<body>
<h1 color="red">预览无效果请刷新</h1>
<ul id="lxf-box">
<li><a href="http://www.iiwnet.com/div_css/342.html"><img src="http://www.iiwnet.com/uploads/allimg/120814/1-120Q411544TX.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/ajax/237.html"><img src="http://www.iiwnet.com/uploads/allimg/120801/1-120P1223013157.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/js_ad/271.html/"><img src="http://www.iiwnet.com/uploads/allimg/120808/1-120PP00915a2.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/js_texiao/312.html/"><img src="http://www.iiwnet.com/uploads/allimg/120812/1-120Q2150022G8.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/js_pic/191.html/"><img src="http://www.iiwnet.com/uploads/allimg/120722/1-120H2144003129.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/js_pic/318.html/"><img src="http://www.iiwnet.com/uploads/allimg/120812/1-120Q2161941b2.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/div_css/341.html/"><img src="http://www.iiwnet.com/uploads/allimg/120814/1-120Q4113240U2.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/div_css/350.html/"><img src="http://www.iiwnet.com/uploads/allimg/120814/125411K11-2.png"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/div_css/350.html/"><img src="http://www.iiwnet.com/uploads/allimg/120814/1254113249-12.png"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/div_css/349.html/"><img src="http://www.iiwnet.com/uploads/allimg/120814/12500a292-1.png"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/php_base/336.html/"><img src="http://www.iiwnet.com/uploads/allimg/120813/1-120Q3145U0938.jpg"></a>
<h3>图片标题</h3>
</li>
<li><a href="http://www.iiwnet.com/div_css/344.html/"><img src="http://www.iiwnet.com/uploads/allimg/120814/12353B521-0.jpg"></a>
<h3>图片标题</h3>
</li>
</ul>
<div id="loading">正在加载……</div>
<script>
/*
原理:1.把所有的li的高度值放到数组里面
2.第一行的top都为0
3.计算高度值最小的值是哪个li
4.把接下来的li放到那个li的下面
<a href="http://iiwnet.com/js_web/">网页特效代码</a>:http://iiwnet.com
编写时间:2012年6月9日
*/ function iiwnet(){//定义成函数便于调用
var wrap = document.getElementById("lxf-box")
var margin = 10;//这里设置间距
var li=$("li");//这里是区块名称
var li_W = li[0].offsetWidth+margin;//取区块的实际宽度(包含间距,这里使用源生的offsetWidth函数,不适用jQuery的width()函数是因为它不能取得实际宽度,例如元素内有pandding就不行了)
var h=[];//记录区块高度的数组
li.css("position","absolute");
var n = wrap.offsetWidth/li_W|0;//容器的宽度除以区块宽度就是一行能放几个区块
for(var i = 0;i < li.length;i++) {//有多少个li就循环多少次
li_H = li[i].offsetHeight;//获取每个li的高度
if(i < n) {//n是一行最多的li,所以小于n就是第一行了
h[i]=li_H;//把每个li放到数组里面
li.eq(i).css("top",0);//第一行的Li的top值为0
li.eq(i).css("left",i * li_W);//第i个li的左坐标就是i*li的宽度
}
else{
min_H =Math.min.apply(null,h) ;//取得数组中的最小值,区块中高度值最小的那个
minKey = getarraykey(h, min_H);//最小的值对应的指针
h[minKey] += li_H+margin ;//加上新高度后更新高度值
li.eq(i).css("top",min_H+margin);//先得到高度最小的Li,然后把接下来的li放到它的下面
li.eq(i).css("left",minKey * li_W); //第i个li的左坐标就是i*li的宽度
}
$("h3").eq(i).text("编号:"+i+",高度:"+li_H);//把区块的序号和它的高度值写入对应的区块H3标题里面
$("li").animate({opacity:1});
}
}
/* 使用for in运算返回数组中某一值的对应项数(比如算出最小的高度值是数组里面的第几个) */
function getarraykey(s, v) {for(k in s) {if(s[k] == v) {return k;}}}
/*这里一定要用onload,因为图片不加载完就不知道高度值*/
window.onload = function() {iiwnet();};
/*浏览器窗口改变时也运行函数*/
window.onresize = function() {iiwnet();}; /**********************************************************************/
/*无限加载*/
var i=1;
function getMore(){
$("#loading").show();
var json = "http://www.iiwnet.com/images/jstx/img.js";
$.getJSON(json, function(data){
$.each(data,function(i){
var url=data[i].url;
var html="<li style='opacity:0'><a href='http://www.iiwnet.com/'><img src="+url+" ></a><h3>图片标题</h3></li>";
$("#lxf-box").append(html);
$("#loading").hide();
});
iiwnet();
i=1
});
};
/*滚动到底部的时候*/
$(window).bind("scroll",function(){
if( $(document).scrollTop() + $(window).height() > $(document).height() - 10 && i==1) {
i=0;
getMore(); }
});
</script>
</body>
</html><p>
<!--ad-->
<script type="text/javascript">/*640*60,创建于2012-8-8*/ var cpro_id = 'u1015696';</script><script src="http://cpro.baidu.com/cpro/ui/c.js" type="text/javascript"></script>
</p>

  

Ajax+json+jquery实现无限瀑布流布局的更多相关文章

  1. jquery实现简单瀑布流布局

    jquery实现简单瀑布流布局 是开头都会说的原理 瀑布流布局有两种,一种是固定列,一种是非固定列.在此主要记述第一种的实现. 固定列的特征是:无论页面如何缩放,每行的总列数都一致. 一行4列的瀑布流 ...

  2. jquery实现简单瀑布流布局(续):图片懒加载

    # jquery实现简单瀑布流布局(续):图片懒加载 这篇文章是jquery实现简单瀑布流布局思想的小小扩展.代码基于前作的代码继续完善. 图片懒加载就是符合某些条件时才触发图片的加载.最常见的具体表 ...

  3. Ajax json jquery实现菜单案例

    需求: 运用AJAX请求文件menu.json,配置菜单栏,并实现以下功能点: 1. 点击向左箭头,菜单向左移动,隐藏 2. 点击向右箭头,菜单向右移动,显示3. 点击一级菜单,被点击菜单的子菜单显示 ...

  4. AJAX+json+jquery实现预加载瀑布流布局

    宽度是一定的高度不定的瀑布流布局 也可以说是无缝拼图 当浏览器滚动到底部时候自动加载图片 加载的图片地址用json 在img.js里 ,还有正在加载动画是用 css3制作的 在ff等支持css3可以显 ...

  5. jQuery Wookmark Load 瀑布流布局实例演示

    瀑布流布局非常适合大量图片的展示,一改过去裁剪图片尺寸统一的排版,每张图片都能完全展示,并错落有致,让人眼前一亮. 版本: jQuery v1.4.3+ jQuery Wookmark Load v1 ...

  6. php ajax json jquery 记录

    php+jquery+ajax+json简单小例子 <html> <title>php+jquery+ajax+json简单小例子</title> <?php ...

  7. 使用jquery+css实现瀑布流布局

    虽然可以直接使用css实现瀑布流布局,但显示的方式有点问题,所以这儿就直接使用jquery+css来实现瀑布流布局,最终效果如下:      思路是通过将每个小块的position设置为relativ ...

  8. springboot04 Ajax json Jquery

    一.Ajax 1.同步&异步请求 在所有的请求响应交互世界里,我们有通常会划分出来两种形态的请求, 一种是同步请求.另一种是异步请求 .比如注册.登录.添加数据等等这些请求执行的就是同步请求, ...

  9. ajax json jQuery提示parsererror错误解决办法

    $.ajax({ type:'POST', url:'<%=basePath%>/xxx.do', dataType:'JSON', data:{ }, success:function( ...

随机推荐

  1. SharePoint 2013 APP 开发示例 (六)服务端跨域访问 Web Service (REST API)

    上个示例(SharePoint 2013 APP 开发示例 (五)跨域访问 Web Service (REST API))是基于JavaScript,运行在web browser内去访问REST AP ...

  2. 洛谷P5206 数树

    题意: task0,给定两棵树T1,T2,取它们公共边(两端点相同)加入一张新的图,记新图连通块个数为x,求yx. task1,给定T1,求所有T2的task0之和. task2,求所有T1的task ...

  3. A1027. Colors in Mars

    People in Mars represent the colors in their computers in a similar way as the Earth people. That is ...

  4. 在 CentOS 6.x 上安装最新版本的 git

    在 CentOS 的默认仓库中有git,所以最简单的方法是: $ sudo yum install git 这种方法虽然简单,但是一般仓库里的版本更新不及时,比如 CentOS 仓库中的 git 最新 ...

  5. idea中的language level 介绍

    language level 介绍 其他 IDE 没有看到类似 language level 的设置,所以这个功能应该算是 IntelliJ IDEA 特有的,可是 IntelliJ IDEA 官网也 ...

  6. Hadoop生态圈-使用Ganglia监控flume中间件

    Hadoop生态圈-使用Ganglia监控flume中间件 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Ganglia监控简介 加州伯克利大学千禧计划的其中一个开源项目.是一 ...

  7. CSS实现文字竖排排版

    CSS实现文字竖排 注意: writing-mode: vertical-rl;存在兼容性问题,在IE上正常,在谷歌的低版本上可能识别不了. 如果文字少的话考虑直接在每一个文字中间加一个<br& ...

  8. vue-router源码分析

    上一篇我们写了前端路由,这几天比较闲,抽空研究了vue.js官方路由的vue-router的实现. 本文主要是以vue-router2.7.0(https://github.com/vuejs/vue ...

  9. 运用Zabbix实现内网服务器状态及局域网状况监控(2) —— 环境配置

    一.基本要求 Zabbix支持如下操作系统: LinuxIBM AIXFreeBSDNetBSDOpenBSDHP-UXMac OS XSolarisWindows: 2000, Server 200 ...

  10. Kettle基本概念学习

    一,理解开发环境与生产环境. 比如,在windows或mac下设计好流程之后,把该设计文件上传到linux集群的机器上执行.那么,在windows下进行的工作即为开发环境,任务具体在linxu机器上执 ...