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
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











入門コード例で Python プログラミングについて学ぶ Python は、習得が簡単でありながら強力なプログラミング言語です。初心者にとって、Python プログラミングの入門コード例を理解することは非常に重要です。この記事では、すぐに始めるのに役立つ具体的なコード例をいくつか紹介します。 Print HelloWorldprint("HelloWorld") これは、Python の最も単純なコード例です。 print()関数は、指定された内容を出力するために使用されます。

「Go 言語プログラミングの例: Web 開発におけるコード例」 インターネットの急速な発展に伴い、Web 開発はさまざまな業界で不可欠な部分になりました。 Go 言語は、強力な機能と優れたパフォーマンスを備えたプログラミング言語として、Web 開発の開発者にますます好まれています。この記事では、読者が Go 言語をより深く理解し、Go 言語を使用して独自の Web アプリケーションを構築できるように、具体的なコード例を通じて Web 開発に Go 言語を使用する方法を紹介します。 1. シンプルな HTTP サーバー まず、

PHP 変数はプログラムの実行中に値を保存し、動的でインタラクティブな WEB アプリケーションを構築するために重要です。この記事では、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. 配列 配列は基本的なデータ構造であり、同じ型のグループです。

Java 選択ソート方法のコード記述ガイドと例 選択ソートは、シンプルで直観的なソート アルゴリズムです。そのアイデアは、ソートされていない要素から毎回最小 (または最大) の要素を選択し、すべての要素がソートされるまで交換することです。この記事では、選択項目の並べ替えのためのコード作成ガイドを提供し、特定の Java サンプル コードを添付します。アルゴリズム原理 選択ソートの基本原理は、ソート対象の配列をソート済み部分とソートされていない部分の 2 つの部分に分割し、その都度、未ソート部分から最小 (または最大) の要素が選択され、ソート済み部分の最後に配置されます。上記を繰り返します
