jQuery 瀑布流 绝对定位布局(二)(延迟AJAX加载图片)_jquery

瀑布流-绝对定位布局,与浮动布局的区别在于

1.布局不一样:
  绝对定位:一个UL里面放置所有的绝对定位的LI;
  浮动布局:多个(一般三四个)UL分布放置LI;
2.AJAX不一样
  绝对定位:只需要将请求来的JSON数据(当然可以是别的格式的数据),插入到UL就可以了。然后再对这个新插入的LI进行TOP和LEFT设置;
  浮动布置:是将请求来的JSON数据(当然可以是别的格式的数据),分别插入到对应的UL当中,因为有绝对定位,所以不用对LI设置位置。会自动向下排列;

一、功能分析:

  1.定位每一个LI,即设置每一个LI的TOP和LEFT值;
  2.将AJAX的数据,放在LI中,插入到UL当中;

二、实现过程:

  1.设置LI的LEFT;
    在那一列?有了列数再乘以每个LI的宽度,就可以确定LEFT值
    找规律:
    现在我需要三列,那么每一列当中的LI,都有一个共同的列号(自己设置0.1.2或者A.B.C,总之自己对这三列给一个标识)这里设为
    0号第一列
    1号第二列
    2号第三列
    所以每一行,只能放三个LI
    第一个li 在 0号 第二个li 在 1号 第三个li 在 2号
    第四个li 在 0号 第五个li 在 1号 第六个li 在 2号
    所以想到用索引取模,正好可以得出0 1 2 ,0 1 2 ……
    通过这个我们就可以判断LI在那一列;
    index%3 = 0 1 2 ,0 1 2 ……
    为什么要模3,因为要得出三个数的循环。所以以后要想得出这样的循环,都可以考虑取模运算;
  2.设置TOP的值;
    因为每一列的总高度值都是不一样的。所以我们要设三个变量来存放不同列的高度值。
    为什么要取得这个值?
    1.初次加载的时候LI,的TOP值,是根据当前列高度值来设置的;
2.因为AJAX请求后的数据LI要插入到UL当中,必需知道当前列现在的总高度,然后给新的LI为它的TOP值;
其实中间有很多可以说的。但实在是太长了。我代码中注释也写的很清楚了。有问题可以留言和我交流。!!
要提一点的就是,里面有很多相同的功能,我都写到一个FUNCTION当中,方便调用。例如要设LI的TOP和LEFT,要获取LI的列数,要设置列的总高度。这都是共公的,也是功能块,所以还是单独用函数写出来好;

复制代码 代码如下:

(function($){
$.fn.extend({
waterfall:function(value){
value=$.extend({
jsonUrl:"",
dataType:"",
cloum:"",
liWidth:""
},value)
//引用包函布瀑布流的DIV对象
var $this = $(this);
//存放列的充号
var colmLeftIndex = 0;
//用来存放每一列的高度值;
var liHeight_0 = 0;
var liHeight_1 = 0;
var liHeight_2 = 0;

//设置列的序号
function getcolums(col){
colmLeftIndex = col%value.cloum;
}
//设置当前列的高度
function getLiHeight(colIndex,hei){
switch(colIndex){
case 0:
liHeight_0 += hei
break;
case 1:
liHeight_1 += hei;
break;
case 2:
liHeight_2 += hei;
break;
}
}
//设置每一个LI的TOP和LEFT
function setLiOffset(oli,liH){
switch(colmLeftIndex){
case 0 :
oli.css({"left":value.liWidth*colmLeftIndex,"top":liHeight_0});
getLiHeight(colmLeftIndex,liH);
console.log(liHeight_0);
break;
case 1:
oli.css({"left":value.liWidth*colmLeftIndex,"top":liHeight_1});
getLiHeight(colmLeftIndex,liH);
break;
case 2:
oli.css({"left":value.liWidth*colmLeftIndex,"top":liHeight_2});
getLiHeight(colmLeftIndex,liH);
break;
}
}

//初次加载时,遍历所有的LI,并定位每一个LI的TOP和LEFT值
$this.find("li").each(function(index, element){
//当前LI的引用
var $liThis = $(this);
//获得当前LI的高度值
var liH = $liThis.outerHeight();
//获得当前列的序号
getcolums(index);
//把当前LI的高度值存到相应的列的总高度变量中
setLiOffset($liThis,liH)

});
//判断每个UL的最后一个LI,是否进入可视区域
function see(objLiLast){
//浏览器可视区域的高度
var see = document.documentElement.clientHeight;
//滚动条滑动的距离
var winScroll = $(this).scrollTop();
//每个UL的最后一个LI,距离浏览器顶部的
var lastLisee = objLiLast.offset().top
return lastLisee < (see+winScroll)?true:false;
}
//是否发出AJAX的“开关”;
var onOff = true;
$(window).scroll(function(){
//拖动滚条时,是否发送AJAX的一个“开关”
$this.children("ul").each(function(index, element) {
//引用当前的UL
var ulThis = this;
//引用最后一个LI
var lastLi = $("li:last",ulThis);
//调用是否进入可视区域函数
var isSee = see(lastLi);
if(isSee && onOff){
onOff = false;
//发送AJAX请求,载入新的图片
$.ajax({
url:value.jsonUrl,
dataType:value.dataType,
success:function(data){
//对返回JSON里面的list数据遍历
$.each(data.list,function(keyList,ovalue){
//对LIST里面的SRC数组遍历,取到图片路径
$.each(ovalue,function(keySrc,avalue){
$.each(avalue,function(keysrc1,value1){
var $imgLi = $("<li><a href=''><img src='" + value1 + "' alt='' /><p>11111</p></a></li>")
//这里开始和浮动布局不一样了。其它部分在调用AJAX的时候,是一样的;因为这里不需要指定插入到那个UL;
$this.children("ul").append($imgLi);
//获取这个新插入到页面中的LI的列的序号
var _liindex = $imgLi.index();
getcolums(_liindex);
//获取这个新插入到页面中的LI的高度值
var _nlih = $imgLi.outerHeight();
//设置当前LI的TOP和LEFT
setLiOffset($imgLi,_nlih);
})
})
onOff = true;
})
}
})
}
});
})
}
})
})(jQuery)

DEMO下载 (这个要在本地机器上安装服务器平台。我用的是PHP套装APPSERV,里面的是APACHE)

时间: 2024-09-30 18:46:10

jQuery 瀑布流 绝对定位布局(二)(延迟AJAX加载图片)_jquery的相关文章

jQuery 瀑布流 浮动布局(一)(延迟AJAX加载图片)_jquery

浮动布局:即HTML结构的列,是用浮动方式. 一.功能分析: 1.判断图片是否进入可视区域: 2.用AJAX请求服务器数据: 3.将数据播入到相应的列队: 二.实现方法: 给window的scroll事件l绑定一个处理函数:做如下工作: 1.如何判断最后一行的图片,是否进入了可视区域? 如果:最后一行的某个图片距离浏览器可视区域顶部的距离值 小于 (可视区域的高度+滚动条滑动的距离值): 那么:就可以判定这个图片进入了浏览器的可视区域: 2.如何用AJAX请求服务器数据; $.getJSON()

JQuery实现Ajax加载图片的方法_jquery

本文实例讲述了JQuery实现Ajax加载图片的方法.分享给大家供大家参考,具体如下: 最近在学习JQuery,想从原理上模拟一下无刷新的相册浏览. 最先想到的思路是利用缓存,也就是先显示提示消息,然后get图片,在get完的时候回调,将img标签的src改掉,由于刚刚get过,有了缓存,所以图片会立刻显示出来. 页面元素: <input class="picbtn" type="button" value="Next" /> <

Ajax加载图片

ajax|加载 在坛子里看见一贴子<如何用javascript显示二进制数据图片>看了他们的回复,没中要害,楼主的主要意思是后台入BinaryWrite()输出一张图片,Ajax接收时如何把它显示出来..回贴的五颜六色,众说风云..其实楼主的意思是要求图片数据接收没有完成以前保持"图片加载中..."的效果给用户,一旦数据完成接收则立即显示.. 我们知道用数据库保存的二进制图片数据都是先通过后台读取数据,输入到客户端.在Asp.Net中我们用Response.BinaryWr

布局-Android imageloade异步加载图片的,怎么知道图片是否加载完成?

问题描述 Android imageloade异步加载图片的,怎么知道图片是否加载完成? -image-loade 用了这个异步加载图片包,怎么知道图片加载完成? 想当加载完成,再显示layout,而不是显示一张图片.. 解决方案 imageloader有回调函数的. ImageLoader.getInstance().displayImage(uri, imageView, new ImageLoadingListener() { @Override public void onLoading

Jquery promise实现一张一张加载图片_jquery

Promise是CommonJS的规范之一,拥有resolve.reject.done.fail.then等方法,能够帮助我们控制代码的流程,避免函数的多层嵌套.如今异步在web开发中越来越重要,对于开发人员来说,这种非线性执行的编程会让开发者觉得难以掌控,而Promise可以让我们更好地掌控代码的执行流程,jQuery等流行的js库都已经实现了这个对象,年底即将发布的ES6也将原生实现Promise. 在javascript设计模式实践之代理模式--图片预加载中用代理模式实现了图片预加载功能.

Jquery仿淘宝京东多条件筛选可自行结合ajax加载示例_jquery

复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="JquerySort.aspx.cs" Inherits="demo_JquerySort" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www

jQuery 源代码显示控件 (Ajax加载方式)._jquery

直接引用远程文件就可以显示源文件,确实解决了资源.在线演示:http://img.jb51.net/online/jquery_codeview/jquery_code.htm打包下载:http://xiazai.jb51.net/200905/yuanma/jquery_codeview.rar

ajax加载出的数据的class属性 jquery能用class做选择器吗

问题描述 ajax加载出的数据的class属性 jquery能用class做选择器吗 ajax加载出的数据的class属性 jquery能用class做选择器吗 解决方案 可以,但是ajax加载的内容必须要添加到dom树后才能调用jquery选择元素,要不找不到对象..注意选择对象的时机. 解决方案二: ajax可以在它的onsuccess事件中得到处理返回,然后再jquery用选择器获取对应的class属性 解决方案三: 我把数据html+=''+item.storeRank+"";

Jquery瀑布流插件使用介绍_jquery

瀑布流布局浅析 浅谈个人在瀑布流网页的实现中遇到的问题和解决方法 折腾:瀑布流布局(基于多栏列表流体布局实现) javascript 瀑布流.各大瀑布流简析与建议 因为自己用jquery比较多,便萌生了把瀑布流做成插件的想法,图片就借用迅雷UED上的那些美图吧. 先看看Demo 把代码放出来吧 复制代码 代码如下: ;(function($){ var //参数 setting={ column_width:204,//列宽 column_className:'waterfall_column'