用js实现瀑布流布局以及通过模拟的数据加载图片,已标记注释

效果如图:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>瀑布流布局-JS实现</title>
</head>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
#main{
position: relative;/*整体相对定位,因为每个小图片盒子的位置是通过计算再由绝对定位放置,是需要相对于main盒子*/
}
.box{
padding: 15px 0 0 15px;/*padding为内边距,后面js获取的高度包括padding的距离*/
float: left;
}
.pic{
padding: 10px;
border: 1px solid #ccc;
border-radius: 5px;
box-shadow: 0 0 5px #ccc;
}
.pic img{
width: 165px;
height: auto;
}
</style>
<script type="text/javascript">
window.onload=function(){
var oParent=document.getElementById("main");
var oBoxs=oParent.getElementsByClassName("box");
waterfall('main','box');//调用瀑布布局的函数
var dataInt={"data":[{"src":'23.jpg'},{"src":'24.jpg'},{"src":'25.jpg'}]}//模拟出要加载的图片
window.onscroll=function(){
if(checkscrollSlide()){//如果调用函数的返回结果为true
//将数据块渲染到当前页面底部
for(var i=0;i<dataInt.data.length;i++){//dataInt对象的data属性的长度
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){
var oParent=document.getElementById(parent);
var oBoxs=oParent.getElementsByClassName(box);
var oBoxW=oBoxs[0].offsetWidth;//计算每个box的宽度
//计算整个页面显示的列数(页面宽/box的宽)
var cols=Math.floor(document.documentElement.clientWidth/oBoxW);
//设置main的宽,居中
oParent.style.cssText='width:'+oBoxW*cols+'px;margin:0 auto;';
var hArr=[];//存放每一列高度的数组
for(var i=0;i<oBoxs.length;i++){
if(i<cols){
hArr.push(oBoxs[i].offsetHeight);//将第一行的各个高度加到数组中
}else{
var minH=Math.min.apply(null,hArr);//apply方法可以改变数组的指向,因为Math.min方法不支持数组
var index=getMinhIndex(hArr,minH);
oBoxs[i].style.position='absolute';
oBoxs[i].style.top=minH+'px';
oBoxs[i].style.left=oBoxs[index].offsetLeft+'px';
hArr[index]+=oBoxs[i].offsetHeight;
}
}
}
function getMinhIndex(arr,val){
for(var i in arr){
if(arr[i]==val){
return i;
}
}
}
//检测是否具备了滚动条加载数据块的条件
function checkscrollSlide(){
//最后一个盒子的距顶部的高度加上自身高度的一半
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;
}
}
</script>
<body>
<div id="main">
<div class="box">
<div class="pic">
<img src="img/0.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/1.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/2.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/3.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/4.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/5.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/6.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/7.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/8.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/9.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/10.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/11.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/12.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/13.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/14.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/15.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/16.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/17.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/18.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/19.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/20.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/21.jpg" />
</div>
</div>
<div class="box">
<div class="pic">
<img src="img/22.jpg" />
</div>
</div>
</div>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# 瀑布流
# 原生JS实现响应式瀑布流布局
# 解析瀑布流布局:JS+绝对定位的实现
# 微信小程序通过js实现瀑布流布局详解
# 纯js实现瀑布流布局及ajax动态新增数据
# 原生JS实现美图瀑布流布局赏析
# JavaScript瀑布流布局实现代码
# 详解javascript实现瀑布流绝对式布局
# JS实现瀑布流布局
# javascript瀑布流布局实现方法详解
# js实现瀑布流布局(无限加载)
# 加载
# 不支持
# 如图
# 相对于
# 大家多多
# 再由
# 滚动条
# 组中
# 具备了
# img
# shadow
# radius
# height
# width
# left
# pic
# border
# ccc
# solid
# auto
相关文章:
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
建站之星如何一键生成手机站?
表情包在线制作网站免费,表情包怎么弄?
行程制作网站有哪些,第三方机票电子行程单怎么开?
安云自助建站系统如何快速提升SEO排名?
建站之星会员如何解锁更多建站功能?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
创业网站制作流程,创业网站可靠吗?
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
在线制作视频网站免费,都有哪些好的动漫网站?
如何在西部数码注册域名并快速搭建网站?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
教学网站制作软件,学习*后期制作的网站有哪些?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
如何通过NAT技术实现内网高效建站?
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
盐城做公司网站,江苏电子版退休证办理流程?
建站之星云端配置指南:模板选择与SEO优化一键生成
如何在腾讯云服务器快速搭建个人网站?
微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
Swift中switch语句区间和元组模式匹配
中山网站推广排名,中山信息港登录入口?
制作农业网站的软件,比较好的农业网站推荐一下?
建站之星安装失败:服务器环境不兼容?
建站之星ASP如何实现CMS高效搭建与安全管理?
如何在Windows虚拟主机上快速搭建网站?
C#如何使用XPathNavigator高效查询XML
宁波自助建站系统如何快速打造专业企业网站?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
如何用西部建站助手快速创建专业网站?
建站主机解析:虚拟主机配置与服务器选择指南
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
制作网站的模板软件,网站怎么建设?
简单实现Android验证码
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
广州美橙建站如何快速搭建多端合一网站?
h5网站制作工具有哪些,h5页面制作工具有哪些?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
如何快速搭建响应式可视化网站?
如何用IIS7快速搭建并优化网站站点?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?
c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
建站主机空间推荐 高性价比配置与快速部署方案解析
简历在线制作网站免费,免费下载个人简历的网站是哪些?
如何在宝塔面板中创建新站点?
*请认真填写需求信息,我们会在24小时内与您取得联系。