Heim php教程 php手册 PHP和Jquery和ajax实现瀑布流

PHP和Jquery和ajax实现瀑布流

Jun 07, 2016 am 11:35 AM

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=&#039;&#039;;<br /> var _url=&#039;<?php echo $this->createUrl(&#039;listXiaohua&#039;);?>&#039;;<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+=&#039;<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_&#039;+q_id+&#039;">&#039;+data[i].title+&#039;<div class="padding-t-5 fx_c_&#039;+q_id+&#039;">&#039;+data[i].content+&#039;&#039;<br /> +&#039;<div class="padding-t-5 text-right"><span onclick="fx(&#039;+q_id+&#039;);" class="fx cursor_p" data-id="&#039;+q_id+&#039;"><span class="g-bg glyphicon glyphicon-share-alt margin-r-5" aria-hidden="true">分享&#039;;<br /> }<br /> }});<br /> return $(html);<br /> },<br /> column_width:376,<br /> column_space:10,<br /> auto_imgHeight:true,<br /> insert_type:1<br /> }<br /> $(&#039;#waterfall&#039;).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元

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Jan 04, 2024 am 10:50 AM

Erfahren Sie anhand einführender Codebeispiele mehr über die Python-Programmierung. Python ist eine leicht zu erlernende und dennoch leistungsstarke Programmiersprache. Für Anfänger ist es sehr wichtig, die einführenden Codebeispiele der Python-Programmierung zu verstehen. In diesem Artikel finden Sie einige konkrete Codebeispiele, die Ihnen den schnellen Einstieg erleichtern. Print HelloWorldprint("HelloWorld") Dies ist das einfachste Codebeispiel in Python. Mit der Funktion print() wird der angegebene Inhalt ausgegeben

Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Mar 04, 2024 pm 04:54 PM

„Beispiele zur Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung“ Mit der rasanten Entwicklung des Internets ist die Webentwicklung zu einem unverzichtbaren Bestandteil verschiedener Branchen geworden. Als Programmiersprache mit leistungsstarken Funktionen und überlegener Leistung wird die Go-Sprache von Entwicklern in der Webentwicklung zunehmend bevorzugt. In diesem Artikel wird anhand spezifischer Codebeispiele erläutert, wie die Go-Sprache für die Webentwicklung verwendet wird, damit die Leser die Go-Sprache besser verstehen und zum Erstellen ihrer eigenen Webanwendungen verwenden können. 1. Einfacher HTTP-Server Beginnen wir zunächst mit a

PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis Feb 19, 2024 pm 03:00 PM

PHP-Variablen speichern Werte während der Programmlaufzeit und sind für den Aufbau dynamischer und interaktiver WEB-Anwendungen von entscheidender Bedeutung. Dieser Artikel wirft einen detaillierten Blick auf PHP-Variablen und zeigt sie anhand von 10 Beispielen aus der Praxis. 1. Benutzereingaben speichern $username=$_POST["username"];$passWord=$_POST["password"]; Dieses Beispiel extrahiert den Benutzernamen und das Passwort aus der Formularübermittlung und speichert sie zur weiteren Verarbeitung in Variablen. 2. Legen Sie den Konfigurationswert $database_host="localhost";$database_username="username";$database_pa fest

Java implementiert einen einfachen Blasensortierungscode Java implementiert einen einfachen Blasensortierungscode Jan 30, 2024 am 09:34 AM

Das einfachste Codebeispiel für die Blasensortierung in Java ist ein allgemeiner Sortieralgorithmus. Seine Grundidee besteht darin, die zu sortierende Reihenfolge durch Vergleich und Austausch benachbarter Elemente schrittweise anzupassen. Hier ist ein einfaches Java-Codebeispiel, das zeigt, wie die Blasensortierung implementiert wird: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Mar 04, 2024 pm 03:09 PM

Titel: Vom Anfänger zur Meisterschaft: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache. Datenstrukturen spielen eine wichtige Rolle in der Programmierung und sind die Grundlage der Programmierung. In der Go-Sprache gibt es viele häufig verwendete Datenstrukturen, und die Beherrschung der Implementierung dieser Datenstrukturen ist entscheidend, um ein guter Programmierer zu werden. In diesem Artikel werden die häufig verwendeten Datenstrukturen in der Go-Sprache vorgestellt und entsprechende Codebeispiele gegeben, um den Lesern den Einstieg bis zur Beherrschung dieser Datenstrukturen zu erleichtern. 1. Array Array ist eine grundlegende Datenstruktur, bei der es sich um eine Gruppe desselben Typs handelt.

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Mit der rasanten Entwicklung der IoT-Technologie und dem Aufstieg des Edge Computing beginnen immer mehr Unternehmen, der Anwendung von Edge Computing Aufmerksamkeit zu schenken. Huawei Cloud bietet Edge-Computing-Dienste und stellt Unternehmen äußerst zuverlässige Computerressourcen und eine praktische Entwicklungsumgebung zur Verfügung, wodurch Edge-Computing-Anwendungen einfacher zu implementieren sind. In diesem Artikel erfahren Sie, wie Sie die Huawei Cloud Edge Computing-Schnittstelle schnell über Java-Code implementieren. Zuerst müssen wir die Entwicklungsumgebung vorbereiten. Stellen Sie sicher, dass Sie das Java Development Kit installiert haben (

So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem Aug 06, 2023 pm 04:49 PM

So schreiben Sie mit PHP den Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem. Die Bestandsverwaltung ist für viele Unternehmen ein unverzichtbarer Bestandteil. Für Unternehmen mit mehreren Lagern ist die Bestandsverwaltungsfunktion besonders wichtig. Durch die ordnungsgemäße Verwaltung und Nachverfolgung des Lagerbestands können Unternehmen den Lagerbestand auf verschiedene Lager verteilen, die Betriebskosten optimieren und die Effizienz der Zusammenarbeit verbessern. In diesem Artikel erfahren Sie, wie Sie mit PHP Code für Lagerverwaltungsfunktionen schreiben und erhalten relevante Codebeispiele. 1. Richten Sie die Datenbank ein, bevor Sie mit dem Schreiben des Codes für die Lagerverwaltungsfunktion beginnen.

Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Feb 18, 2024 am 10:52 AM

Code-Schreibanleitung und Beispiele für die Java-Auswahlsortierung Die Auswahlsortierung ist ein einfacher und intuitiver Sortieralgorithmus. Die Idee besteht darin, jedes Mal das kleinste (oder größte) Element aus den unsortierten Elementen auszuwählen und es auszutauschen, bis alle Elemente sortiert sind. Dieser Artikel enthält eine Anleitung zum Schreiben von Code für die Auswahlsortierung und fügt spezifischen Java-Beispielcode hinzu. Algorithmusprinzip Das Grundprinzip der Auswahlsortierung besteht darin, das zu sortierende Array in zwei Teile zu unterteilen: sortiert und unsortiert. Dabei wird jeweils das kleinste (oder größte) Element aus dem unsortierten Teil ausgewählt und am Ende des sortierten Teils platziert. Wiederholen Sie das oben Gesagte

See all articles