JavaScript實(shí)現(xiàn)瀑布流圖片效果
更新時(shí)間:2021年09月17日 08:27:39 作者:jasonduanmu
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)瀑布流圖片效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了js實(shí)現(xiàn)瀑布流圖片效果的具體代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> *{ margin: 0; padding: 0; } #wrap{ position: relative; list-style: none; margin: 0 auto; } #wrap li{ width: 200px; font-size: 1.5rem; position: absolute; background-color: #CCCCCC; -webkit-transition: all 2s; } #wrap li div{ width: 100%; height: 100%; overflow: hidden; } </style> </head> <body> <ul id="wrap"></ul> </body> <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script> <script type="text/javascript"> $(function(){ function randomFunction(max , min){ return parseInt(Math.random() * (max - min)) + min; } var wrapUL = document.getElementById("wrap"); var width = 200; var rightPadding = 10; var hs = []; var num = 0; function setLiPos(bol){ var lis = wrapUL.getElementsByTagName("li"); var windowBody = document.documentElement.clientWidth; var cols = parseInt(windowBody / width); wrapUL.style.width = cols * (width + rightPadding) + "px"; var arrT = []; for (var i = 0; i < cols; i++) { arrT[i] = 0; } function createLi(index){ var li = lis[index]||document.createElement("li"); var h = hs[index] || randomFunction(100, 300); li.style.height = h + "px"; if(bol){ hs.push(h); } var min = arrT[0]; var minIndex = 0; for (var i = 0; i < arrT.length; i++) { if(min > arrT[i]){ min = arrT[i]; minIndex = i; } } li.style.top = arrT[minIndex] + "px"; li.style.left = minIndex * (width + rightPadding) + "px"; arrT[minIndex] += (h + rightPadding); bol&&wrapUL.appendChild(li); } for(var i = 0; i < 20; i++){ if(bol){ num++; } createLi(i); } } setLiPos(true); window.onresize = function(){ setLiPos(false); } }); </script> <script type="text/javascript"> $(function(){ var imgArr = ["1.jpg","2.jpg","3.jpg","4.jpg","5.jpg","6.jpg","7.jpg"]; $("li").each(function(index, el) { var n = RandomNumBoth(0,imgArr.length-1); var imgsrc = imgArr[n]; $(this).html("<div><img onload='loadImage()' src='"+imgsrc+"'></div>"); }); }); function loadImage(){ $("img").each(function(index, el) { var a=$(this).width(), b=$(this).height(), pa = $(this).parent().width(), pb = $(this).parent().height(), e=a/b, //圖片寬高比 3 pe=pa/pb; //承載圖片容器寬高比 if(e>=pe){ $(this).css({height:"100%",width:"auto"}); var imgW = $(this).width(), iW = $(this).parent().width(), w = -(imgW - iW)/2; $(this).css('marginLeft',w); }else{ $(this).css({width:"100%",height:"auto"}); var imgH = $(this).height(), iH = $(this).parent().height(), h = -(imgH - iH)/2; $(this).css('marginTop',h); } }); } function RandomNumBoth(Min,Max){ var Range = Max - Min; var Rand = Math.random(); var num = Min + Math.round(Rand * Range); return num; } </script> </html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- js實(shí)現(xiàn)的美女瀑布流效果代碼
- javascript自適應(yīng)寬度的瀑布流實(shí)現(xiàn)思路
- 原生JS實(shí)現(xiàn)響應(yīng)式瀑布流布局
- 解析瀑布流布局:JS+絕對(duì)定位的實(shí)現(xiàn)
- 純js實(shí)現(xiàn)瀑布流展現(xiàn)照片(自動(dòng)適應(yīng)窗口大小)
- js實(shí)現(xiàn)瀑布流的一種簡(jiǎn)單方法實(shí)例分享
- js實(shí)現(xiàn)瀑布流的三種方式比較
- 純js實(shí)現(xiàn)瀑布流布局及ajax動(dòng)態(tài)新增數(shù)據(jù)
- javascript實(shí)現(xiàn)瀑布流加載圖片原理
- js實(shí)現(xiàn)仿百度瀑布流的方法
相關(guān)文章
微信小程序?qū)崿F(xiàn)跳轉(zhuǎn)的幾種方式總結(jié)(推薦)
這篇文章主要介紹了微信小程序跳轉(zhuǎn)方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04javascript實(shí)現(xiàn)簡(jiǎn)單打字游戲
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)簡(jiǎn)單打字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10解決在Bootstrap模糊框中使用WebUploader的問題
這篇文章主要介紹了在Bootstrap模糊框中使用WebUploader的問題及解決方法,,需要的朋友可以參考下2018-03-03在小程序中集成redux/immutable/thunk第三方庫(kù)的方法
這篇文章主要介紹了在小程序中集成redux/immutable/thunk第三方庫(kù)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08