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 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











소개 코드 예제를 통해 Python 프로그래밍에 대해 알아보세요. Python은 배우기 쉽지만 강력한 프로그래밍 언어입니다. 초보자의 경우 Python 프로그래밍의 입문 코드 예제를 이해하는 것이 매우 중요합니다. 이 문서에서는 빠르게 시작하는 데 도움이 되는 몇 가지 구체적인 코드 예제를 제공합니다. Print HelloWorldprint("HelloWorld") 이것은 Python에서 가장 간단한 코드 예제입니다. print() 함수는 지정된 내용을 출력하는 데 사용됩니다.

"Go 언어 프로그래밍 예제: 웹 개발의 코드 예제" 인터넷의 급속한 발전과 함께 웹 개발은 다양한 산업에서 없어서는 안 될 부분이 되었습니다. 강력한 기능과 뛰어난 성능을 갖춘 프로그래밍 언어인 Go 언어는 웹 개발 개발자들의 선호도가 점점 높아지고 있습니다. 이 기사에서는 특정 코드 예제를 통해 웹 개발에 Go 언어를 사용하는 방법을 소개하므로 독자는 Go 언어를 더 잘 이해하고 사용하여 자신의 웹 애플리케이션을 구축할 수 있습니다. 1. 간단한 HTTP 서버 먼저 시작해 보겠습니다.

PHP 변수는 프로그램 런타임 중에 값을 저장하며 동적 및 대화형 웹 애플리케이션을 구축하는 데 중요합니다. 이 기사에서는 PHP 변수를 심층적으로 살펴보고 10가지 실제 예제를 통해 실제로 작동하는 모습을 보여줍니다. 1. 사용자 입력 저장 $username=$_POST["username"];$passWord=$_POST["password"] 이 예에서는 양식 제출에서 사용자 이름과 비밀번호를 추출하여 추가 처리를 위해 변수에 저장합니다. 2. 구성 값 $database_host="localhost";$database_username="username";$database_pa를 설정합니다.

Java 버블 정렬의 가장 간단한 코드 예제 버블 정렬은 인접한 요소의 비교와 교환을 통해 순서가 지정된 순서로 정렬되는 순서를 점진적으로 조정하는 일반적인 정렬 알고리즘입니다. 다음은 버블 정렬을 구현하는 방법을 보여주는 간단한 Java 코드 예제입니다. publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

PHP를 사용하여 재고 관리 시스템에서 재고 관리 기능 코드를 작성하는 방법 재고 관리는 많은 기업에서 없어서는 안될 부분입니다. 창고가 여러 개인 회사의 경우 재고 관리 기능이 특히 중요합니다. 재고를 적절하게 관리하고 추적함으로써 회사는 서로 다른 창고 간에 재고를 할당하고, 운영 비용을 최적화하며, 협업 효율성을 향상시킬 수 있습니다. 이 기사에서는 PHP를 사용하여 재고 창고 관리 기능을 위한 코드를 작성하는 방법을 소개하고 관련 코드 예제를 제공합니다. 1. 재고 창고 관리 기능에 대한 코드 작성을 시작하기 전에 데이터베이스를 구축하십시오.

Huawei 클라우드 엣지 컴퓨팅 상호 연결 가이드: 인터페이스를 신속하게 구현하기 위한 Java 코드 샘플 IoT 기술의 급속한 발전과 엣지 컴퓨팅의 부상으로 점점 더 많은 기업이 엣지 컴퓨팅 애플리케이션에 관심을 갖기 시작했습니다. Huawei Cloud는 엣지 컴퓨팅 서비스를 제공하여 기업에 매우 안정적인 컴퓨팅 리소스와 편리한 개발 환경을 제공하여 엣지 컴퓨팅 애플리케이션을 보다 쉽게 구현할 수 있도록 합니다. 이 기사에서는 Java 코드를 통해 Huawei Cloud 엣지 컴퓨팅 인터페이스를 빠르게 구현하는 방법을 소개합니다. 먼저 개발 환경을 준비해야 합니다. Java Development Kit가 설치되어 있는지 확인하십시오(

제목: 초보자에서 숙달까지: Go 언어에서 일반적으로 사용되는 데이터 구조의 코드 구현 데이터 구조는 프로그래밍에서 중요한 역할을 하며 프로그래밍의 기초입니다. Go 언어에는 일반적으로 사용되는 데이터 구조가 많이 있으며 이러한 데이터 구조의 구현을 마스터하는 것은 좋은 프로그래머가 되는 데 중요합니다. 이 기사에서는 Go 언어에서 일반적으로 사용되는 데이터 구조를 소개하고 독자가 이러한 데이터 구조에 익숙해지는 데 도움이 되는 해당 코드 예제를 제공합니다. 1. 배열(Array) 배열은 기본 자료구조로, 같은 형태의 그룹

Java 선택 정렬 방법 코드 작성 가이드 및 예제 선택 정렬은 정렬되지 않은 요소 중에서 가장 작은(또는 가장 큰) 요소를 매번 선택하고 모든 요소가 정렬될 때까지 교환하는 간단하고 직관적인 정렬 알고리즘입니다. 이 기사에서는 선택 정렬을 위한 코드 작성 가이드를 제공하고 특정 Java 샘플 코드를 첨부합니다. 알고리즘 원리 선택 정렬의 기본 원리는 정렬할 배열을 정렬된 부분과 정렬되지 않은 부분의 두 부분으로 나누는 것입니다. 매번 정렬되지 않은 부분에서 가장 작은(또는 가장 큰) 요소가 선택되어 정렬된 부분의 끝에 배치됩니다. 위의 내용을 반복하세요.
