利用JavaScript怎么实现一个瀑布流效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
公司主营业务:成都做网站、成都网站设计、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出苏尼特左免费做网站回馈大家。JavaScript是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript是被广泛用于客户端的脚本语言,最早是在HTML网页上使用,用来给HTML网页增加动态功能。
//一个main包含了整个页面内容,box用来做一个外容器,img作为图片容器//CSS //这里面的填充用padding值,因为offsetHeight是包括一个padding而不包括margin的方便以后高度的测量 *{ margin: 0px; padding: 0px; } #main{ position: relative;//在main上设置相对定位,在JS给box设置绝对定位,来控制图片位置 } .box{ padding: 15px 0 0 15px; float: left; } .pic{ padding: 10px; border: 1px solid #ccc; border-radius:5px; box-shadow: 0 0 5px #ccc; } .pic img{ width: 168px;//瀑布流统一宽度但不同一高度,高度为自适应就好 height: auto; }JS代码
在我们写JS代码之前,我们需要搞明白我们需要什么方法,是否需要封装起来调用,我们第一步要干什么,
那么我们第一步要干什么呢?我们做瀑布流首先要做的是获取到所有小部件也就是box,我们无论做什么处理都是对box的处理或者img的处理,所以要获取到所有的box,所以我们可以把它封装起来//根据class获取元素 function getByClass(parent,clsName){//传入父元素和想要的class 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 //push是数组自带的方法 }; return boxArr;返回数组 }这样我们就得到了我们想要的class,之后该怎么办呢,先从一个box下手,我们需要取得第一排到底有多少个元素,因为之前我们并没有确定我们main的宽度,所以是自适应的也就是说我们把页面缩小,我们每一排的元素也会相应的减少,为了能让瀑布流的代码有更好的应用性,让不同尺寸的图片都可以应用,所以,我们需要手动计算一排究竟可以放多少张图片呢,那如何计算呢?
我们可以算出页面总宽在box的宽,就OK了var oBoxW=oBoxs[0].offsetWidth;//box的宽,提到了里面计算了padding的值
var clos=Math.floor(document.documentElement.clientWidth/oBoxW)//求列数
这样我们就求出了列数,无论图片的宽度如何变,我们都可以算出来
floor是用来取整数的,因为我们的px是没有浮点数类型的避免计算错误,所以取整
oparent.style.cssText='width:'+oBoxW*clos+'px; margin :0 auto';
设置main的宽度我们已经取得了列数之后呢我们第一排的图片肯定是一排宽度相等,长度不一是吧,也就是说,我们第二排的图片需要接上第一排图片的后边,我们不能一排一排操作,但我们可以一个一个操作,怎么操作呢,我们可以取到第一排高度最小的将下一张图片,也就是如果第一排7个,那下一个就是第八个,把第八个图片放在最小高度的图片上,如何实现呢,我们先试想一下,我们首先需要求出第一排中最小,我们有一个Math.min求最小,但是呢我们这个函数无法传入用数组,只能是具体的数怎么半呢,apply来扩展作用域
用代码展示下var hArr=[];//每一列高度的值 for (var i = 0; i < oBoxs.length; i++) { if(i以上就大体做出了一个瀑布流的样式,就差拖动滚动条加载了,这里面肯定需要后台的支持,在慕课上,老师做了一个伪处理,这里建议看慕课视频,有图解十分清楚,我用语言或图片不太好表达
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完整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看完上述内容,你们掌握利用JavaScript怎么实现一个瀑布流效果的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联成都网站设计公司行业资讯频道,感谢各位的阅读!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享文章:利用JavaScript怎么实现一个瀑布流效果-创新互联
网页地址:http://cdkjz.cn/article/diggjc.html