亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于JavaScript實現瀑布流效果(循環漸近)

2019-11-20 10:40:47
字體:
來源:轉載
供稿:網友

1.建立Html模版

想法是先用一個div container承載所有內容,然后div box用來放置圖片,最后div box_border來當圖片框,代碼如下

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>瀑布流</title></head><body><div class="container" id="container"><div class="box_border" id="box_border"><div class="box" id="box1"><img src="image/01.jpg"></div><!--把Box復制多份,這里因為代碼重復省略了--></div></div></body></html>

效果:(未設置css屬性所以都是垂直放置的)

2.通過css簡單設置樣式

主要設置水平放置,相框顏色,邊界之類的

/*邊界不留空,背景黑灰*/body{margin: 0px;background: darkgray;}/*總布局設置為相對布局*/.container{position: relative;}/*設置box屬性*/.box{padding: 5px;float: left;}/*設置圖片邊框陰影和圓角*/.box_border{padding: 5px;border: 1px solid #cccccc;box-shadow: 0px 0px 5px #ccc;border-radius: 5px;}/*設置圖片格式*/.box_border img{width: 150px;height: auto;}

效果:(邊框什么都有了)

這里寫圖片描述

3.JS控制每一行所擺放的圖片個數

上面的css布局之后,瀏覽器窗口大小改變,里面的圖片數量也會改變,現在要用JS固定住每一行的圖片數量,對于不同尺寸的屏幕都能做到很好的效果

/*用于加載其他函數*/window.onload = function(){setImgLocation("container");}/*設置圖片個數*/function setImgLocation(parent){var cparent = document.getElementById(parent);//得到父節點var childArray = getChildNodes(cparent);//得到圖片數量var imgWidth = childArray[0].offsetWidth;//獲取照片寬度var screenWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度var count = Math.floor(screenWidth/imgWidth);//每行的個數cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中}/*獲取全部圖片的個數*/function getChildNodes(parent){var childArray =[];//定義一個數組存放圖片boxvar tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點//循環添加class為box的節點for(var i = 0;i<tempNodes.length;i++){if(tempNodes[i].className == "box"){childArray.push(tempNodes[i]);}}return childArray;//返回所有的子節點}

效果圖:針對不同屏幕大小顯示的個數是不一樣的

這里寫圖片描述

4.JS實現靜態瀑布流

先實現靜態的布局,也就是瀏覽器下拉不會自動刷新出新的圖片.

實現排列算法很簡單

1.把第一排圖片的高度全部存到一個數組
2.計算出第一排中的圖片的最小高度和對應位置
3.把第一排之后的第一個圖片放到該位置上
4.重新設置該位置的高度為兩個圖片相加
5.循環2剩余全部圖片

代碼:

/*用于加載其他函數*/window.onload = function(){setImgLocation("container");}/*設置圖片個數及位置排列*/function setImgLocation(parent){var cparent = document.getElementById(parent);//得到父節點var childArray = getChildNodes(cparent);//得到圖片數量var imgWidth = childArray[0].offsetWidth;//獲取照片寬度var screenWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度var count = Math.floor(screenWidth/imgWidth);//每行的個數cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中//定義數組,存放第一行照片高度var imgHArray = [];//循環遍歷圖片for(var i=0;i<childArray.length;i++){//如果圖片在第一行則獲取高度if(i<count){imgHArray[i] = childArray[i].offsetHeight;}else//否則把最小高度的填充剩余圖片{var minHeight = Math.min.apply(null,imgHArray);//獲取最小高度var minIndex = getMinIndex(minHeight,imgHArray);//獲取最小高度對應的下標childArray[i].style.position = "absolute";//設置要填充的圖片盒子為絕對布局,否則不能更換位置childArray[i].style.top = minHeight+"px";//設置要填充圖片距頂高度childArray[i].style.left = childArray[minIndex].offsetLeft+"px";//設置要填充圖片距左高度imgHArray[minIndex] += childArray[i].offsetHeight;//填充后把當前位置高度設為兩個圖片相加//開始下一輪循環}}}/*獲取最小高度對應的下標*/function getMinIndex(minHeight,imgHArray){for(var i in imgHArray){if(imgHArray[i] == minHeight){return i;}}}/*獲取全部圖片的個數*/function getChildNodes(parent){var childArray =[];//定義一個數組存放圖片boxvar tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點//循環添加class為box的節點for(var i = 0;i<tempNodes.length;i++){if(tempNodes[i].className == "box"){childArray.push(tempNodes[i]);}}return childArray;//返回所有的子節點}

效果:

這里寫圖片描述

5.js實現動態加載

動態加載也就是滾動條永遠滑不到底部,要解決動態加載我們需要考慮兩個問題:

1.什么時候加載?

滑動距離+瀏覽器高度>最后一張圖片距離頂部的距離

2.怎樣加載?

通過創建新的節點,把創建的節點添加進去即可

最終代碼:

/*用于加載其他函數*/window.onload = function() {var cparent = document.getElementById("container");//得到父節點setImgLocation(cparent);//設置加載的圖片var data = ["image/01.jpg", "image/02.jpg", "image/03.jpg", "image/04.jpg", "image/05.jpg", "image/06.jpg", "image/07.jpg", "image/08.jpg", "image/09.jpg","image/11.jpg", "image/12.jpg", "image/13.jpg", "image/14.jpg", "image/15.jpg", "image/16.jpg", "image/17.jpg"];//滑動監聽window.onscroll = function () {if (checkLoad(cparent)) {for (var i = 0; i < data.length; i++) {//創建新的節點var div1 = document.createElement("div");div1.className = "box";var div2 = document.createElement("div");div2.className = "box_border";var img = document.createElement("img");img.className = ".box_border img";img.src = data[i];div2.appendChild(img);div1.appendChild(div2);cparent.appendChild(div1);}setImgLocation(cparent);//創建節點后重新排列}}}/*檢查是否應該加載*/function checkLoad(cparent){var childArray = getChildNodes(cparent);//得到圖片個數var lastImgHight = childArray[childArray.length-1].offsetTop;//得到最后一張圖片距離頂部高度var scrollHeight = document.documentElement.scrollTop||document.body.scrollTop;//獲得滑動距離(瀏覽器兼容性真煩人)var browserHeight = document.documentElement.clientHeight;//獲得瀏覽器高度if(lastImgHight < scrollHeight+browserHeight){//判斷是否加載return true;}else {return false;}}/*設置圖片個數及位置排列*/function setImgLocation(cparent){var childArray = getChildNodes(cparent);//得到圖片數量var imgWidth = childArray[0].offsetWidth;//獲取照片寬度var browserWidth = document.documentElement.clientWidth;//獲取瀏覽器寬度var count = Math.floor(browserWidth/imgWidth);//每行的個數cparent.style.cssText = "width:"+count*imgWidth+"px;margin: 0 auto;";//設置其寬度并居中//定義數組,存放第一行照片高度var imgHArray = [];//循環遍歷圖片for(var i=0;i<childArray.length;i++){//如果圖片在第一行則獲取高度if(i<count){imgHArray[i] = childArray[i].offsetHeight;}else//否則把最小高度的填充剩余圖片{var minHeight = Math.min.apply(null,imgHArray);//獲取最小高度var minIndex = getMinIndex(minHeight,imgHArray);//獲取最小高度對應的下標childArray[i].style.position = "absolute";//設置要填充的圖片盒子為絕對布局,否則不能更換位置childArray[i].style.top = minHeight+"px";//設置要填充圖片距頂高度childArray[i].style.left = childArray[minIndex].offsetLeft+"px";//設置要填充圖片距左高度imgHArray[minIndex] += childArray[i].offsetHeight;//填充后把當前位置高度設為兩個圖片相加//開始下一輪循環}}}/*獲取最小高度對應的下標*/function getMinIndex(minHeight,imgHArray){for(var i in imgHArray){if(imgHArray[i] == minHeight){return i;}}}/*獲取全部圖片的個數*/function getChildNodes(parent){var childArray =[];//定義一個數組存放圖片boxvar tempNodes = parent.getElementsByTagName("*");//獲取父節點下的所有節點//循環添加class為box的節點for(var i = 0;i<tempNodes.length;i++){if(tempNodes[i].className == "box"){childArray.push(tempNodes[i]);}}return childArray;//返回所有的子節點}

效果:

這里寫圖片描述

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色偷偷91综合久久噜噜| 日韩av在线一区二区| 日韩视频免费看| 成人精品视频久久久久| 久久久久久久久久亚洲| 精品亚洲va在线va天堂资源站| 国产日韩欧美日韩| 亚洲黄色www网站| 国产精品视频色| 久久亚洲春色中文字幕| 91麻豆桃色免费看| 最近2019免费中文字幕视频三| 国产精品视频内| 国产成人亚洲综合91精品| 97人人爽人人喊人人模波多| 亚洲精品免费网站| 亚洲精品永久免费| 欧美最顶级丰满的aⅴ艳星| 欧美老女人xx| 国产精品视频内| 热久久99这里有精品| 国产精品99久久99久久久二8| 中文字幕亚洲综合久久| 精品久久中文字幕| 久久精品国产欧美亚洲人人爽| 中文字幕欧美精品在线| 日韩国产精品视频| 成人做爽爽免费视频| 国产精品色午夜在线观看| 成人做爰www免费看视频网站| 欧美日韩国产一区二区三区| 精品福利在线视频| 成人在线视频网| 欧美中文在线免费| 色噜噜狠狠狠综合曰曰曰88av| 91精品国产乱码久久久久久蜜臀| 日本伊人精品一区二区三区介绍| 国产精品影片在线观看| 久久精品99久久久香蕉| 久久久精品久久久久| 成人福利在线视频| 欧美黑人性生活视频| 久久国产精品久久久久久久久久| 最近的2019中文字幕免费一页| 九九热这里只有在线精品视| 欧美日韩国产激情| 欧美视频在线观看 亚洲欧| 国产精品7m视频| 欧美成人精品一区| 亚洲97在线观看| 精品欧美aⅴ在线网站| 亚洲18私人小影院| 超碰97人人做人人爱少妇| 欧美午夜精品久久久久久浪潮| 久久99热精品这里久久精品| 一区二区三区四区视频| 亚洲xxxx做受欧美| 国产精品自产拍在线观看| 欧美与黑人午夜性猛交久久久| 国产精品99久久久久久白浆小说| 亚洲第一色在线| 午夜美女久久久久爽久久| www亚洲欧美| 精品久久香蕉国产线看观看gif| 亚洲第一综合天堂另类专| 国产综合视频在线观看| 久久亚洲国产精品成人av秋霞| 精品亚洲va在线va天堂资源站| 日韩精品在线视频| 欧美亚洲国产成人精品| 久久久久久免费精品| 亚洲欧美精品一区二区| 日韩精品有码在线观看| 欧美天天综合色影久久精品| 日韩亚洲在线观看| 国产69久久精品成人看| 欧美精品国产精品日韩精品| 日韩精品高清在线观看| 国产成人精品一区二区| 亚洲国产精品人人爽夜夜爽| 一区二区三区视频观看| 国产69精品久久久久9999| 亚洲v日韩v综合v精品v| 国产精品福利在线| 97免费视频在线| 国产欧美欧洲在线观看| 国产欧美日韩精品丝袜高跟鞋| 久久91精品国产91久久久| 欧美视频精品一区| 亚洲白拍色综合图区| 亚洲二区中文字幕| 成人av.网址在线网站| 亚洲图片在区色| 国产精品一区=区| 揄拍成人国产精品视频| 日本欧美中文字幕| www.欧美三级电影.com| 国产成人精品av在线| 亚洲色图偷窥自拍| 韩国三级日本三级少妇99| 久久久久亚洲精品国产| 91久久在线观看| 国产精品福利网| 成人www视频在线观看| 国内精品一区二区三区四区| 成人免费网站在线看| 亚洲免费一级电影| 欧美猛少妇色xxxxx| 欧美大片va欧美在线播放| 91在线观看欧美日韩| 中文字幕v亚洲ⅴv天堂| 色老头一区二区三区在线观看| 成人免费xxxxx在线观看| 欧美性色19p| 色综久久综合桃花网| 欧美国产亚洲精品久久久8v| 久久中文字幕国产| 尤物九九久久国产精品的特点| 国产精品久久久久久av下载红粉| 久久久久久久香蕉网| 日韩av网站大全| 欧美日韩国产精品一区二区不卡中文| 久久人人爽人人爽人人片亚洲| 成人在线视频网站| 欧美成人激情视频免费观看| 亚洲国产女人aaa毛片在线| 人妖精品videosex性欧美| 亚洲欧美国产va在线影院| 欧美亚洲视频在线观看| 亚洲成人免费网站| 国产精品女视频| 国产成人福利视频| 亚洲国产精久久久久久久| 久久免费高清视频| 亚洲第一精品久久忘忧草社区| 亚洲国产美女久久久久| 成人黄色免费片| 国产精品一区二区三区毛片淫片| 欧美日韩成人在线视频| 亚洲男人天堂2023| 日韩欧美在线免费观看| 欧美激情视频免费观看| 久久大大胆人体| 中文字幕亚洲天堂| 成人欧美一区二区三区黑人| 色综合久久精品亚洲国产| 最近2019年日本中文免费字幕| 久久高清视频免费| 九九久久综合网站| 亚洲乱码国产乱码精品精天堂| 亚洲精品美女在线观看| 精品久久久久久亚洲精品| 久久伊人精品一区二区三区| 91成人在线视频| 在线丨暗呦小u女国产精品| 97在线观看视频国产| 国产精品com| 亚洲一区二区三区在线免费观看| 国产精品一区电影| 成人免费直播live| 久久精品电影一区二区| 亚洲免费视频网站| 国产精品香蕉av| 一区二区成人精品|