jquery瀑布流的製作

来源:http://www.cnblogs.com/xmoomoo/archive/2016/08/18/5784864.html
-Advertisement-
Play Games

首先,還是來看一下炫酷的頁面: 今天就邊做邊說了: 一。準備工作 新建css,js,img文件夾存放相應文件,併在demo.html文件中引入外部文件(註意要把jquery文件引入),這裡就不過多描述了。 二。圖片展示 一個大div包裹全局,小的div包裹圖片,這裡為什麼要這麼多圖片呢,是因為剛開始 ...


首先,還是來看一下炫酷的頁面:

今天就邊做邊說了:

一。準備工作

新建css,js,img文件夾存放相應文件,併在demo.html文件中引入外部文件(註意要把jquery文件引入),這裡就不過多描述了。

二。圖片展示

<div id="main">
    <div class="pic">
        <img src="img/1.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/2.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/3.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/4.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/5.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/6.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/7.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/8.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/9.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/10.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/1.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/2.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/3.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/4.jpg" />
    </div>
     <div class="pic">
        <img src="img/5.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/6.jpg" />
    </div>
    
    <div class="pic">
        <img src="img/7.jpg" />
    </div>
</div>

一個大div包裹全局,小的div包裹圖片,這裡為什麼要這麼多圖片呢,是因為剛開始的時候圖片要占滿屏幕,否則會不美觀。而且jq中用的是監聽滾動條的方法載入圖片,圖片太少的話滾動條都不會出現,自然不能執行滾動條的事件。

分析一下圖片的顯示效果:

1.圖片有白色的邊框,陰影

2.圖片是平鋪的

*{
    padding:0;
    margin:0;
}
#main{
    position:relative;
}
#main .pic{
    width:170px;
    box-shadow: 0 0 6px #CCCCCC;
    float:left;
    margin:5px;
}
#main .pic img{
    width:160px;
    height:auto;
    border: 5px #FFFFFF solid;
}

相信上面的代碼是很好理解的,到此為止圖片已經平鋪了。

三。讓圖片順序依次排列

雖然執行完上面的代碼以後圖片是平鋪了,但效果卻是很不好的,它沒有像圖片展示的那樣高低排列。

如何實現高低排列:

1.第一行肯定是沒有問題的,因為第一行的每張圖上面沒有圖片,也就是說是平的;

2.第二行就可以取第一行中高度最小的圖片,然後把第二行的第一張圖片放在下麵(這裡用絕對定位控製圖片位置);

3.以此類推,把第二行第一張圖片插入以後,在選擇這時候第一行中最短的,並把圖片放在下麵。

function waterFall(){
    var divWidth = $("#main .pic").eq(0).width()+10; //獲取頁面中包裹圖片的div寬度,這裡的+10是因為在css中設置的margin是5px,左右加起來就是10(相當於這個div的實際寬度比預設多10px)
    var num = Math.floor($(window).width()/divWidth); // Math.floor是向下取整,獲取整個瀏覽器的寬度除以"圖片的占寬"可以獲得圖片可以排放多少列,這也就是向下取整的原因了
    
    $("#main").css({  //設置整個div的寬度,並讓其居中顯示
        "width":divWidth*num,
        "margin": "0 auto"    
    });
    var picArr = []; //定義一個數組
    $("#main .pic").each(function(index){ //遍歷所有.pic的div
        var picHeight = $("#main .pic").eq(index).height();//獲取每個div的高度
        if(index<num){ //如果是第一行
            picArr[index] = picHeight;//把高度存儲進數組
        }else{ //如果數組不是第一行的數據了
            var minH = Math.min.apply(null,picArr); //獲取數組中最小的高度
            var minIndex = $.inArray(minH,picArr); //獲取最小高度的index(位置)
            $(this).css({ //設置這個div的位置
                "position":"absolute",
                "top":minH+10, //設置它距離上方的距離,這裡加10是因為在css中設置的margin是5px,上下加起來是10px
                "left":$("#main .pic").eq(minIndex).position().left     //獲取最小高度距離左邊的距離
            });
            picArr[minIndex]+=$("#main .pic").eq(index).height()+10; //把最小的高度存入數組中
        }
    });
}

在頁面載入完後執行waterFall()方法,這個句子就不寫啦。到此為止就可以看到圖片依次有序排列啦

四。瀑布流的實現

思路:這裡是監聽瀏覽器的滾動條,當滾動條到達底部時就載入預定數組中的圖片

$(window).on("load",function(){
    waterFall();
    var pics = ["1.jpg","2.jpg","3.jpg","4.jpg","5.jpg"];
    window.onscroll = function(){
        if ($(document).scrollTop() >= $(document).height() - $(window).height()) {
            $.each(pics,function(index,value){
                $(".pic").eq(0).clone().appendTo("#main").find("img").attr("src","img/"+value);    
            });
            waterFall();
        }
    }
});

appendTo() 方法在被選元素的結尾(仍然在內部)插入指定內容。

當然這裡是當瀏覽器的滾動條到達底部的時候才會載入圖片,如果覺得這樣用戶體驗不好的話,可以在if裡面設置,例如:if ($(document).scrollTop()+100 >= $(document).height() - $(window).height()) 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • h5活動需要插入音頻,但又需要自定義樣式,於是自己寫咯 html css js 以上基本可以實現自定義音頻播放,但是在拖動進度條的時候出現了問題,電腦上是ok的,但是在手機上可以拖動,只不過音頻的總時長比正常播放少了好幾分鐘,導致拖動進度後播放不准確。通過測試發現手機上拿到的duration(總時長 ...
  • 我們可以通過css來做出動畫效果,下麵我為大家演示的是div的旋轉,顏色過渡的動畫 效果自己測試,很絢麗哦 ...
  • × 目錄 [1]元素 [2]特性 [3]文本[4]CDATA[5]實體引用[6]實體名稱[7]處理指令[8]註釋[9]文檔[10]文檔類型[11]文檔片段[12]DTD 前面的話 DOM是javascript操作網頁的介面,全稱為文檔對象模型(Document Object Model)。它的作用是 ...
  • ...
  • 0.快速入門 border-radius:50px; 1.border-radius詳解 border-radius:50px; 上右下左,水平和垂直距離都是50px border-radius:50%; 這裡的%號是已應用該css樣式元素的長度和寬度為基數的 border-radius:50% 3 ...
  • 1. 準備向伺服器發送數據 Ajax 最常見的一大用途是向伺服器發送數據。最典型的情況是從 客戶端發送表單數據,即用戶在form元素所含的各個 input 元素里輸入的值。下麵代碼展示了一張簡單的表單: 這個例子中的表單包含三個input元素和一個提交button 。這些input元素讓用戶可以指定 ...
  • 這幾天做一個項目有用到表格顯示數據的地方,客戶要求重覆的數據列需要合併,就總結了一下GridView 和 Repeater 關於重覆數據合併的方法。 效果圖如下 : GridView : 前臺代碼 : 1 <div> 2 <asp:GridView ID="gvIncome" runat="serv ...
  • 最近在學習使用angular,慢慢從jquery ui轉型到用ng開發,發現了很多不同點,繼續學習吧; 首先創建一個服務,以便在項目中的controller中引用,服務有幾種存在形式,factory();service();constant();value();provider();其中provid ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...