原生JS實作美圖瀑布流佈局賞析_javascript技巧
自pinterest网站爆红以来,国内一度掀起“仿PIN”狂潮,诸如花瓣、蘑菇街等等。正是如此,“瀑布流”式布局受到广大网民的青睐。众多知名JS库,也相继出现“瀑布流”布局插件,譬如jQuery的Masonry插件、KISSY的waterfall插件等。今天闲来无聊,我也自己动手弄了段原生JS代码,实现了简单的“瀑布流”布局效果,当然肯定不能和以上那些优秀插件相提并论,有兴趣的朋友,可以去看看,希望能带给你或多或少的收获。
1. js代码:
<!DOCTYPE html> <html> <head> <meta charset="utf-"> <title>Waterfall代码</title> </head> <body> <style type="text/css"> .wf-main{ position: relative; margin: auto; width: px; overflow: hidden; } .wf-main .wf-cld{ position: absolute; margin-bottom: px; padding:px px; width: px; left: -px; top: -px; line-height:px; border: px solid #; border-radius: px; background-color: #ccc; overflow: hidden; } .wf-cld .inner{ position: absolute; left: -px; top: -px; margin-bottom: px; width: px; overflow: hidden; border: px solid #f; border-radius: px; } .wf-cld .title{ margin: px; padding: px; width: px; color: #f; font-size: px; } </style> <div class="wf-main" id="wf-main"> <div class="wf-cld"><h style="color:#f">、瀑布流</h></div> <div class="wf-cld"><br></div> <div class="wf-cld"><br><br></div> <div class="wf-cld"><br><br><br></div> <div class="wf-cld"><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld" id="wf-inner"> <h class="inner title">、内部瀑布流</h> <div class="inner">-<br></div> <div class="inner">-</div> <div class="inner">-</div> <div class="inner">-</div> <div class="inner">-<br></div> <div class="inner">-</div> <div class="inner">-</div> <div class="inner">-</div> <div class="inner">-</div> </div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> <div class="wf-cld"><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br></div> </div> <script type="text/javascript"> function Waterfall(param){ this.id = typeof param.container == 'string' ? document.getElementById(param.container) : param.container; this.colWidth = param.colWidth; this.colCount = param.colCount || ; this.cls = param.cls && param.cls != '' ? param.cls : 'wf-cld'; this.init(); } Waterfall.prototype = { getByClass:function(cls,p){ var arr = [],reg = new RegExp("(^|\\s+)" + cls + "(\\s+|$)","g"); var nodes = p.getElementsByTagName("*"),len = nodes.length; for(var i = ; i < len; i++){ if(reg.test(nodes[i].className)){ arr.push(nodes[i]); reg.lastIndex = ; } } return arr; }, maxArr:function(arr){ var len = arr.length,temp = arr[]; for(var ii= ; ii < len; ii++){ if(temp < arr[ii]){ temp = arr[ii]; } } return temp; }, getMar:function(node){ var dis = ; if(node.currentStyle){ dis = parseInt(node.currentStyle.marginBottom); }else if(document.defaultView){ dis = parseInt(document.defaultView.getComputedStyle(node,null).marginBottom); } return dis; }, getMinCol:function(arr){ var ca = arr,cl = ca.length,temp = ca[],minc = ; for(var ci = ; ci < cl; ci++){ if(temp > ca[ci]){ temp = ca[ci]; minc = ci; } } return minc; }, init:function(){ var _this = this; var col = [],//列高 iArr = [];//索引 var nodes = _this.getByClass(_this.cls,_this.id),len = nodes.length; for(var i = ; i < _this.colCount; i++){ col[i] = ; } for(var i = ; i < len; i++){ nodes[i].h = nodes[i].offsetHeight + _this.getMar(nodes[i]); iArr[i] = i; } for(var i = ; i < len; i++){ var ming = _this.getMinCol(col); nodes[i].style.left = ming * _this.colWidth + "px"; nodes[i].style.top = col[ming] + "px"; col[ming] += nodes[i].h; } _this.id.style.height = _this.maxArr(col) + "px"; } }; new Waterfall({ "container":"wf-inner", "colWidth":, "colCount":, "cls":"inner" }); new Waterfall({ "container":"wf-main", "colWidth":, "colCount": }); </script> </body> </html>
2. [图片] 瀑布流.jpg

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

本文概述了十個簡單的步驟,可以顯著提高腳本的性能。 這些技術很簡單,適用於所有技能水平。 保持更新:使用bundler(例如vite)的npm等軟件包經理來確保

核心要点 利用 JavaScript 增强结构化标记可以显著提升网页内容的可访问性和可维护性,同时减小文件大小。 JavaScript 可有效地用于为 HTML 元素动态添加功能,例如使用 cite 属性自动在块引用中插入引用链接。 将 JavaScript 与结构化标记集成,可以创建动态用户界面,例如无需页面刷新的选项卡面板。 确保 JavaScript 增强功能不会妨碍网页的基本功能至关重要;即使禁用 JavaScript,页面也应保持功能正常。 可以使用高级 JavaScript 技术(

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何
