PHP和Jquery和ajax实现瀑布流
PHP和Jquery和ajax实现下拉淡出瀑布流效果(无需插件)
不废话,直接上代码,您也可以点这里看瀑布流演示http://www.shouce.ren/post/xiaohua。
前台:<?php <br />
$category=$this->getMyVal('category',$_GET);<br>
$xiaohuaList=Xiaohua::model()->getXiaohao($category); //打开页面默认显示的数据<br>
?><br>
<br>
<div>
<br>
<?php foreach ($xiaohuaList as $xiaohua):?><br>
<?php $q_id=$xiaohua->id;?><br>
<div>
<br>
<div>
<span></span><strong>"><?php echo CHtml::encode($xiaohua->title);?></strong>
</div>
<br>
<div>"><?php echo $xiaohua->content;?></div>
<br>
<div><span>);" class="fx cursor_p" data-id="<?php echo $q_id;?>"><span></span>分享</span></div>
<br>
</div>
<br>
<?php endforeach;?><br>
</div>
<br>
<script><br />
var opt={<br />
getResource:function(index,render){//index为已加载次数,render为渲染接口函数,接受一个dom集合或jquery对象作为参数。通过ajax等异步方法得到的数据可以传入该接口进行渲染,如 render(elem)<br />
var html='';<br />
var _url='<?php echo $this->createUrl('listXiaohua');?>';<br />
$.ajax({<br />
type: "get",<br />
url: _url,<br />
dataType : "json",<br />
async:false,<br />
success: function(data){<br />
for( var i in data){<br />
var q_id=data[i].id;<br />
html+='<div class="cell m-bg item-h border_h"><div class="border-solid-b padding-b-5 text-center"><span class="g-bg glyphicon glyphicon-sunglasses margin-r-5" aria-hidden="true"><strong class="color-5 fx_t_'+q_id+'">'+data[i].title+'<div class="padding-t-5 fx_c_'+q_id+'">'+data[i].content+''<br />
+'<div class="padding-t-5 text-right"><span onclick="fx('+q_id+');" class="fx cursor_p" data-id="'+q_id+'"><span class="g-bg glyphicon glyphicon-share-alt margin-r-5" aria-hidden="true">分享';<br />
}<br />
}});<br />
return $(html);<br />
},<br />
column_width:376,<br />
column_space:10,<br />
auto_imgHeight:true,<br />
insert_type:1<br />
}<br />
$('#waterfall').waterfall(opt);<br />
</script>
后台:public function actionListXiaohua() {<br>
$xiaohuaList=Xiaohua::model()->getXiaohua();//获取笑话信息<br>
echo CJSON::encode($xiaohuaList);<br>
}
js:;(function($){<br>
var<br>
//参数<br>
setting={<br>
column_width:240,//列宽<br>
column_className:'waterfall_column',//列的类名<br>
column_space:2,//列间距<br>
cell_selector:'.cell',//要排列的砖块的选择器,context为整个外部容器<br>
img_selector:'img',//要加载的图片的选择器<br>
auto_imgHeight:true,//是否需要自动计算图片的高度<br>
fadein:true,//是否渐显载入<br>
fadein_speed:600,//渐显速率,单位毫秒<br>
insert_type:1, //单元格插入方式,1为插入最短那列,2为按序轮流插入<br>
getResource:function(index){ } //获取动态资源函数,必须返回一个砖块元素集合,传入参数为加载的次数<br>
},<br>
//<br>
waterfall=$.waterfall={},//对外信息对象<br>
$waterfall=null;//容器<br>
waterfall.load_index=0, //加载次数<br>
$.fn.extend({<br>
waterfall:function(opt){<br>
opt=opt||{};<br>
setting=$.extend(setting,opt);<br>
$waterfall=waterfall.$waterfall=$(this);<br>
waterfall.$columns=creatColumn();<br>
render($(this).find(setting.cell_selector).detach(),false); //重排已存在元素时强制不渐显<br>
waterfall._scrollTimer2=null;<br>
$(window).bind('scroll',function(){<br>
clearTimeout(waterfall._scrollTimer2);<br>
waterfall._scrollTimer2=setTimeout(onScroll,300);<br>
});<br>
waterfall._scrollTimer3=null;<br>
$(window).bind('resize',function(){<br>
clearTimeout(waterfall._scrollTimer3);<br>
waterfall._scrollTimer3=setTimeout(onResize,300);<br>
});<br>
}<br>
});<br>
function creatColumn(){//创建列<br>
waterfall.column_num=calculateColumns();//列数<br>
//循环创建列<br>
var html='';<br>
for(var i=0;i<waterfall.column_num></waterfall.column_num>
html+='<div></div>';<br>
}<br>
$waterfall.prepend(html);//插入列<br>
return $('.'+setting.column_className,$waterfall);//列集合<br>
}<br>
function calculateColumns(){//计算需要的列数<br>
var num=Math.floor(($waterfall.innerWidth())/(setting.column_width+setting.column_space));<br>
if(num
return num;<br>
}<br>
function render(elements,fadein){//渲染元素<br>
if(!$(elements).length) return;//没有元素<br>
var $columns = waterfall.$columns;<br>
$(elements).each(function(i){<br>
if(!setting.auto_imgHeight||setting.insert_type==2){//如果给出了图片高度,或者是按顺序插入,则不必等图片加载完就能计算列的高度了<br>
if(setting.insert_type==1){<br>
insert($(elements).eq(i),setting.fadein&&fadein);//插入元素<br>
}else if(setting.insert_type==2){<br>
insert2($(elements).eq(i),i,setting.fadein&&fadein);//插入元素<br>
}<br>
return true;//continue<br>
}<br>
if($(this)[0].nodeName.toLowerCase()=='img'||$(this).find(setting.img_selector).length>0){//本身是图片或含有图片<br>
var image=new Image;<br>
var src=$(this)[0].nodeName.toLowerCase()=='img'?$(this).attr('src'):$(this).find(setting.img_selector).attr('src');<br>
image.onload=function(){//图片加载后才能自动计算出尺寸<br>
image.onreadystatechange=null;<br>
if(setting.insert_type==1){<br>
insert($(elements).eq(i),setting.fadein&&fadein);//插入元素<br>
}else if(setting.insert_type==2){<br>
insert2($(elements).eq(i),i,setting.fadein&&fadein);//插入元素<br>
}<br>
image=null;<br>
}<br>
image.onreadystatechange=function(){//处理IE等浏览器的缓存问题:图片缓存后不会再触发onload事件<br>
if(image.readyState == "complete"){<br>
image.onload=null;<br>
if(setting.insert_type==1){<br>
insert($(elements).eq(i),setting.fadein&&fadein);//插入元素<br>
}else if(setting.insert_type==2){<br>
insert2($(elements).eq(i),i,setting.fadein&&fadein);//插入元素<br>
}<br>
image=null;<br>
}<br>
}<br>
image.src=src;<br>
}else{//不用考虑图片加载<br>
if(setting.insert_type==1){<br>
insert($(elements).eq(i),setting.fadein&&fadein);//插入元素<br>
}else if(setting.insert_type==2){<br>
insert2($(elements).eq(i),i,setting.fadein&&fadein);//插入元素<br>
}<br>
}<br>
});<br>
}<br>
function public_render(elems){//ajax得到元素的渲染接口<br>
render(elems,true);<br>
}<br>
function insert($element,fadein){//把元素插入最短列<br>
if(fadein){//渐显<br>
$element.css('opacity',0).appendTo(waterfall.$columns.eq(calculateLowest())).fadeTo(setting.fadein_speed,1);<br>
}else{//不渐显<br>
$element.appendTo(waterfall.$columns.eq(calculateLowest()));<br>
}<br>
}<br>
function insert2($element,i,fadein){//按序轮流插入元素<br>
if(fadein){//渐显<br>
$element.css('opacity',0).appendTo(waterfall.$columns.eq(i%waterfall.column_num)).fadeTo(setting.fadein_speed,1);<br>
}else{//不渐显<br>
$element.appendTo(waterfall.$columns.eq(i%waterfall.column_num));<br>
}<br>
}<br>
function calculateLowest(){//计算最短的那列的索引<br>
var min=waterfall.$columns.eq(0).outerHeight(),min_key=0;<br>
waterfall.$columns.each(function(i){<br>
if($(this).outerHeight()<min></min>
min=$(this).outerHeight();<br>
min_key=i;<br>
}<br>
});<br>
return min_key;<br>
}<br>
function getElements(){//获取资源<br>
$.waterfall.load_index++;<br>
return setting.getResource($.waterfall.load_index,public_render);<br>
}<br>
waterfall._scrollTimer=null;//延迟滚动加载计时器<br>
function onScroll(){//滚动加载<br>
clearTimeout(waterfall._scrollTimer);<br>
waterfall._scrollTimer=setTimeout(function(){<br>
var $lowest_column=waterfall.$columns.eq(calculateLowest());//最短列<br>
var bottom=$lowest_column.offset().top+$lowest_column.outerHeight();//最短列底部距离浏览器窗口顶部的距离<br>
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop||0;//滚动条距离<br>
var windowHeight=document.documentElement.clientHeight||document.body.clientHeight||0;//窗口高度<br>
if(scrollTop>=bottom-windowHeight){<br>
render(getElements(),true);<br>
}<br>
},100);<br>
}<br>
function onResize(){//窗口缩放时重新排列<br>
if(calculateColumns()==waterfall.column_num) return; //列数未改变,不需要重排<br>
var $cells=waterfall.$waterfall.find(setting.cell_selector);<br>
waterfall.$columns.remove();<br>
waterfall.$columns=creatColumn();<br>
render($cells,false); //重排已有元素时强制不渐显<br>
}<br>
})(jQuery);
好了,全部完成了。这里看瀑布流演示http://www.shouce.ren/post/xiaohua。
AD:真正免费,域名+虚机+企业邮箱=0元

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

了解Python程式設計的入門程式碼範例Python是一種簡單易學,功能強大的程式語言。對於初學者來說,了解Python程式設計的入門級程式碼範例是非常重要的。本文將為您提供一些具體的程式碼範例,幫助您快速入門。列印HelloWorldprint("HelloWorld")這是Python中最簡單的程式碼範例。 print()函數用於將指定的內容輸出

PHP變數儲存程式運行期間的值,對於建立動態且互動的WEB應用程式至關重要。本文將深入探討php變量,並透過10個真實的範例展示它們的實際應用。 1.儲存使用者輸入$username=$_POST["username"];$passWord=$_POST["password"];此範例從表單提交中提取使用者名稱和密碼,並將其儲存在變數中以供進一步處理。 2.設定配置值$database_host="localhost";$database_username="username";$database_pa

《Go語言程式設計實例:Web開發中的程式碼範例》隨著網路的快速發展,Web開發已成為各行業中不可或缺的一部分。作為一門功能強大且效能優越的程式語言,Go語言在Web開發中越來越受到開發者們的青睞。本文將透過具體的程式碼範例,介紹如何利用Go語言進行Web開發,讓讀者更能理解並運用Go語言來建立自己的Web應用。 1.簡單的HTTP伺服器首先,讓我們從一個

Java冒泡排序最簡單的程式碼範例冒泡排序是一種常見的排序演算法,它的基本想法是透過相鄰元素的比較和交換來將待排序序列逐步調整為有序序列。以下是一個簡單的Java程式碼範例,示範如何實作冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能碼庫存管理是許多企業中不可或缺的一部分。對於擁有多個倉庫的企業來說,庫存分倉管理功能尤其重要。透過合理管理和追蹤庫存,企業可以實現不同倉庫之間的庫存調撥,優化營運成本,改善協同效率。本文將介紹如何使用PHP編寫庫存分倉管理功能的程式碼,並為您提供相關的程式碼範例。一、建立資料庫在開始編寫庫存分倉管理功能的程式碼之

華為雲端邊緣運算對接指南:Java程式碼範例快速實現介面隨著物聯網技術的快速發展和邊緣運算的興起,越來越多的企業開始關注邊緣運算的應用。華為雲端提供了邊緣運算服務,為企業提供了高可靠的運算資源和便利的開發環境,使得邊緣運算應用更容易實現。本文將介紹如何透過Java程式碼快速實現華為雲端邊緣運算的介面。首先,我們需要準備好開發環境。確保你已經安裝了Java開發工具包(

標題:從入門到精通:Go語言中常用資料結構的程式碼實作資料結構在程式設計中起著至關重要的作用,它是程式設計的基礎。在Go語言中,有許多常用的資料結構,掌握這些資料結構的實作方式對於成為優秀的程式設計師至關重要。本文將介紹Go語言中常用的資料結構,並給出對應的程式碼範例,幫助讀者從入門到精通這些資料結構。 1.數組(Array)數組是一種基本的資料結構,是一組相同類型

Java選擇排序法程式碼編寫指南及範例選擇排序是一種簡單直觀的排序演算法,其想法是每次從未排序的元素中選擇最小(或最大)的元素進行交換,直到所有元素排序完成。本文將提供選擇排序的程式碼編寫指南,並附上具體的Java範例程式碼。演算法原理選擇排序的基本原理是將待排序數組分為已排序和未排序兩部分,每次從未排序部分選擇最小(或最大)的元素,將其放到已排序部分的末尾。重複上述
