JS原生瀑布流效果实现(2)

以上就大体做出了一个瀑布流的样式,就差拖动滚动条加载了,这里面肯定需要后台的支持,在慕课上,老师做了一个伪处理,这里建议看慕课视频,有图解十分清楚,我用语言或图片不太好表达

var dataInt={"data":[{"src":'0.jpg'},{"src":'1.jpg'},{"src":'2.jpg'},{"src":'3.jpg'}]}//我们自己写一个json数据 window.onscroll=function(){ if(checkScrollSlide){ var oparent=document.getElementById("main") //将数据快渲染到当前页面尾部 for (var i = 0; i < dataInt.data.length; i++) {//添加 var oBox=document.createElement("div"); oBox.className="box"; oparent.appendChild(oBox); var opic=document.createElement('div'); opic.className='pic'; oBox.appendChild(opic); var oimg=document.createElement('img'); oimg.src='img/'+dataInt.data[i].src;//将数据加进去 opic.appendChild(oimg) } waterfall('main','box');//一会看完整代码,这就是刚才那些的封装 } } function checkScrollSlide(){//检测是否具备加载数据块的条件 var oparent=document.getElementById('main'); var oBoxs=getByClass(oparent,'box') var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2)求出最后一个图片的一半距离页面顶端的距离 var scrollTop=document.body.scrollTop||document.documentElement.scrollTop; var height=document.body.clientHeight||document.documentElement.clientHeight; return(lastBoxH<scrollTop+height)?true:false;//如果页面距离顶部(包括滚轮)的距离比滚轮加页面距离小,那么就返回true }

完整JS代码

window.onload=function(){ waterfall('main','box'); //json var dataInt={"data":[{"src":'0.jpg'},{"src":'1.jpg'},{"src":'2.jpg'},{"src":'3.jpg'}]} window.onscroll=function(){ if(checkScrollSlide){ var oparent=document.getElementById("main") //将数据快渲染到当前页面尾部 for (var i = 0; i < dataInt.data.length; i++) { var oBox=document.createElement("div"); oBox.className="box"; oparent.appendChild(oBox); var opic=document.createElement('div'); opic.className='pic'; oBox.appendChild(opic); var oimg=document.createElement('img'); oimg.src='img/'+dataInt.data[i].src; opic.appendChild(oimg) } waterfall('main','box'); } } } function waterfall(parent,box){ //将main下所有class为box的元素取出来 var oparent=document.getElementById(parent); var oBoxs=getByClass(oparent,box) //console.log(oBox.length) //计算整个页面的列数(页面宽/box宽) var oBoxW=oBoxs[0].offsetWidth; //console.log(oBoxW); var clos=Math.floor(document.documentElement.clientWidth/oBoxW)//求列数 //console.log(clos) //设置main的宽 oparent.style.cssText='width:'+oBoxW*clos+'px; margin :0 auto'; var hArr=[];//每一列高度的值 for (var i = 0; i < oBoxs.length; i++) { if(i<clos){ hArr.push(oBoxs[i].offsetHeight); }else{ var minH=Math.min.apply(Math,hArr); //console.log(minH) var index=getMinhIndex(hArr,minH)//索引 oBoxs[i].style.position="absolute"; oBoxs[i].style.top=minH+"px"; oBoxs[i].style.left=oBoxW*index+"px"; hArr[index]+=oBoxs[i].offsetHeight;//更改数组 } }; //console.log(hArr) } //根据class获取元素 function getByClass(parent,clsName){ var boxArr=new Array//用来存储获取到所有class为box的元素 oElements=parent.getElementsByTagName('*');//取出所有子元素 for (var i = 0; i < oElements.length; i++) { if(oElements[i].className==clsName) boxArr.push(oElements[i]);//取出传过来相等的className }; return boxArr; } function getMinhIndex (arr,val){ for(var i in arr){ if(arr[i]==val){ return i; } } } function checkScrollSlide(){//检测是否具备加载数据块的条件 var oparent=document.getElementById('main'); var oBoxs=getByClass(oparent,'box') var lastBoxH=oBoxs[oBoxs.length-1].offsetTop+Math.floor(oBoxs[oBoxs.length-1].offsetHeight/2) var scrollTop=document.body.scrollTop||document.documentElement.scrollTop; var height=document.body.clientHeight||document.documentElement.clientHeight; return(lastBoxH<scrollTop+height)?true:false; }

我的瀑布流图

JS原生瀑布流效果实现

以上所述是小编给大家介绍的JS原生瀑布流效果实现详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/f7ca4f4acabed91da9742a04e7d5c3c8.html